JPA表关联关系(多对一、一对多、多对多、一对一)

版权声明:《==study hard and make progress every day==》 https://blog.csdn.net/qq_38225558/article/details/84109136

小提示:外键在哪边,那边就是多方哦!!

单向多对一:   给多方加上 @ManyToOne

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查询),没有查询条件才使用查询缓存
  ⑤不用一对一,用多对一取代(不要使用共享主键一对一,使用唯一外键一对一)
  ⑥灵活使用单向多对一关联

 

猜你喜欢

转载自blog.csdn.net/qq_38225558/article/details/84109136
今日推荐