关系:数据库
实体关系是指实体与实体之间的关系,从方向上分为单向关联和双向关联,从实体数量上分为一对1、一对多、多对多等。对于任何两个实体,都要从这两个方面区分它们之间的关系。fetch
一对一两种配置方式:spa
1:主键共享(把一个实体的主键配置为另一个实体的主键)blog
2:配合惟一外键it
单项一对多class
:配置一个实体的外键 数据库外键存在多方,最好让多方来维护外键 ,一方放弃管理维护配置
双向多对一/双向一对多im
public class ProductDir {d3
@Id数据
@GeneratedValue
private Long id;
private String name;
@OneToMany
@JoinColumn(name="dir_id")
private Set<Product> products = new HashSet<Product>();
@Entity
public class Product {
@Id
@GeneratedValue
private Long id;
private String name;
@ManyToOne(fetch = FetchType.LAZY) // 实现延迟加载
@JoinColumn(name = "dir_id")
private ProductDir dir;
集合映射的类型
1.list PersistentBag(有序,能够重复)
2.set PersistentSet(无序,不能够重复)
级联
:
级联保存 PERSIST
级联删除 REMOVE
所有 ALL
孤儿删除 orphanRemoval = true (从一方解除关系,让多方外键置为空)
单项多对多
@ManyToMany
@joinTable 中间表配置
joinColumns:首 个列名 inverseJoinColumns: 下个列名
实体类没什么变化 默认懒加载 只配置一个实体类
双向多对多
列Teacher/Student