import javax.persistence.*;
一对多:
/**
* OneToMany:指明Classes与Student之间是一对多关系,Classes是主类,Student是关系类
* cascade:定义类和类之间的级联关系,对当前类对象及其关联类对象采取相同的操作
* fetch:定义检索策略,FetchType.EAGER(主类加载时关系类就加载)和FetchType.LAZY(关系类调用时才加载),在这里当然要lazy
* mappedBy:定义类之间的双向关系,如果类之间是双向关系就需要定义,其值是"多"方类中"一"方的变量名
* targetEntity:关系类的类类型
* OrderBy("id asc"):加载关系类时按照id升序(降序desc)
* mappedBy="classes"
*/
@OneToMany(
cascade=CascadeType.ALL,
fetch=FetchType.LAZY,
targetEntity=Student.class
)
@JoinColumn(name="classes_id",referencedColumnName="id")
private Set<Student> students = new HashSet<Student>(0);
多对一:
/**
* @ManyToOne 学生--班级 多对一
* classes_id:关联字段
* cascade:设定级联操作
* cascade=CascadeType.ALL
* fetch:是否懒加载,不要设置此处为lazy,否则会报错illegally attempted to associate a proxy with two open Sessions
* fetch=FetchType.LAZY
* optional:关联字段是否允许为空
*/
@ManyToOne(optional=true)
@JoinColumn(name="classes_id")
private Classes classes;
多对多
/**
* 多对多:老师-学生
*/
@ManyToMany
@JoinTable(name="th_st",inverseJoinColumns={@JoinColumn(name="teacher_id")},joinColumns={@JoinColumn(name="student_id")})
//Fecth策略定义
@Fetch(FetchMode.SUBSELECT)
//集合按id排序.
@OrderBy("id")
private Set<Teacher> teacherList = new HashSet<Teacher>(0);
级联操作的使用场景:
@ManyToOne
@OneToMany
级联删除
级联增加