
公司的一个旧项目,数据库的表与表不建立外键,为什么 hibernate 还能够 进行多对一 一对多 查询?
另外,不建立外键 多对一会有什么影响吗?
mybatis 一定是需要建立外键吧? 我记得我不建立不会查询成功
1 Jacky23333 2020-09-16 15:04:31 +08:00 via Android 啊,这 |
2 dorothyREN 2020-09-16 15:08:28 +08:00 这问题太难了,还是让楼下来解答吧 |
3 gz911122 2020-09-16 15:08:52 +08:00 mybatis 不需要的 |
4 sleaves 2020-09-16 15:14:27 +08:00 除了以前学校建过外键外,开发了这么久就没建过什么外键,都是代码约束 |
5 tctc4869 2020-09-16 15:17:08 +08:00 外键并不一定是物理以上,数据库里的外键,外键也有可能靠实体类代码进行约束,比如通过注解。这种外键,在数据库那里当然看不出外键。 |
6 Jacky23333 2020-09-16 15:25:25 +08:00 via Android @tctc4869 你还是没看懂楼主的意思 |
7 Jacky23333 2020-09-16 15:29:47 +08:00 via Android @tctc4869 你的意思就是说,数据库表没有建立外键还能查询是因为代码里面有了逻辑外键,也就是你觉得,外键是多表查询实现的基础? |
8 checkZH 2020-09-16 15:31:59 +08:00 有一点可以明确,mybatis 是不需要的 |
9 liuzhaowei55 2020-09-16 16:02:57 +08:00 via Android 外键是约束,而不是物理关联吧。 我这样理解的 |
10 Jrue0011 2020-09-16 16:17:19 +08:00 mybatis 的 association 和 collection 也不需要外键约束,一对一、一对多这些应该是实体关系而不是外键吧。 注解指定了关联字段,orm 就能根据注解信息生成 SQL 用于查询,甚至新增和删除(作用就好像数据库的外键约束)。 |
11 hyperbin 2020-09-16 17:19:42 +08:00 via Android 约束只管 insert,不管 select |
12 qwerthhusn 2020-09-16 17:43:36 +08:00 spring.jpa.hibernate.ddl-auto=validate 再试试看 默认的话是 none,这时 Hibernate 认为你的 Entity 定义和数据库定义都是 OK 的 他只是生成这样的 SQL 去执行,但是此时有没有外键都能成功执行这个 SQL |
13 zsdroid 2020-09-16 18:03:45 +08:00 外键 ( foreign key ) 是用于建立和加强两个表数据之间的链接的一列或多列。 我觉得关系表必定存在外键(数据库级别的实体外键,代码里的逻辑外键),也就是 jion on 部分。 |
14 zsdroid 2020-09-16 18:04:08 +08:00 外键应该是广义上的关系键 |