jpa 映射关系
ex:【产品类Product--多方 ,产品分类ProductDir--一方】
单向一对多:给一方加上 @OneToMany
ex:【产品类Product--多方 ,产品分类ProductDir--一方】
双向多对一、一对多: 给多方加上 @ManyToOne,给一方加上 @OneToMany
ex:【部门类Department--一方 ,员工类Employee--多方】
多对多:有中间表的就是多对多
ex:【多个teacher,多个student】
单向多对多 -->给其中一个多方加 @ManyToMany
双向多对多:2个多方都加 @ManyToMany
一对一: 加上 @OneToOne
ex:【一个qq号对应一个qq空间】 (下面是唯一外键一对一)
如何优化JPA??
①使用双向一对多关联,不使用单向一对多
②表字段要少,表关联不要怕多,有二级缓存撑腰,设计表尽量达到第三方式
③组合关系集合使用list(顺序,重复),多对多集合使用set
④配置对象二级缓存,不使用集合二级缓存,如果使用了集合二级缓存,集合里面的对象也必须二级缓存;查询缓存(jpql查询),没有查询条件才使用查询缓存
⑤不用一对一,用多对一取代(不要使用共享主键一对一,使用唯一外键一对一)
⑥灵活使用单向多对一关联
---------------------
作者:郑清
来源:CSDN
原文:https://blog.csdn.net/qq_38225558/article/details/84109136
版权声明:本文为博主原创文章,转载请附上博文链接!
注意地方 :
- ,需要用mapperBy“(另一边的外键)” 交给另一方维护关系 ,有mapperBy 的 一方, 无法操作另一边的数据;