1.单向多对一的关联关系
运行,产生如下数据表,外键customer_id就是Customer表中的主键
使用如下方式,实现懒加载
不能直接删除1的一端,因为有外键约束
2.单向1对多的关联关系
单向1-n关联关系执行保存时,一定会多出update语句,因为n的一端在插入时不会同时插入外键列
执行查询时,默认使用懒加载的策略,如下方式修改懒加载策略
删除时,把n的一端的外键置空,然后删除1的一端,要想级联删除,如下方式:
3.双向多对一的关联关系
相当于单边1-n 和单边n-1 相加
若双向1-n的关联关系,
执行保存时,若先保存n的一端,再保存1的一端,默认情况下会多出4条update语句,若先保存1的一端,则
会多出n条update语句,在进行双向1-n关联关系时,建议使用n的一方来维护关联关系,而1的一方不维护关联关系,这样可以有效的减少sql语句;如果让1的一方放弃维护关系,方式如下:
若在1的一端@OneToMany的mappedBy属性,则 @OneToMany则不能再使用@JoinColumn属性
4.双向一对一的关联关系
双向1-1的关联关系,建议先保存不维护关联关系的一方,即没有外键的一方,这样不会多出update
默认情况下:
若获取维护关联关系的一方,则会通过左外链接获取其关联的对象,可如下方式实现懒加载:
若先获取不维护关联关系的一方,也是左外链接获取其关联的对象,即便修改了懒加载,但依然会发送sql语句来初始化其关联对象,说明在不维护关联关系一方,不建议修改
5.双向多对多的关联关系
对于关联的集合对象,默认使用懒加载的策略
本文学习自尚硅谷官网视频