一对多,反过来就是,多对一。在进行一对多的映射中,往往也要处理多对一。
涉及到的注解(注解的使用看代码注释):
- OneToMany
- ManyToOne
- JsonIgnoreProPerties
举个例子:
一个教室有多个同学,多个同学在一个教室上课。
@Entity
@Table(name = "t_student")
public class Student {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@Column(name = "name")
private String name;
/**
* Student 和 Classroom是多对一的关系所以用到了ManyToOne注解。
*
* 因此每一个Student实例也都有一个classroom实例,
* 所以student对应的数据库表个也就需要一个外键来关联classroom实例(通过JoinColumn.name),
* 同时通过JoinColumn.referencedColumnName来指出外键对应的主键名称。
*
*/
@ManyToOne
@JoinColumn(name="classroom_id",referencedColumnName="id")
@JsonIgnoreProperties(value="students")
private Classroom classroom;
@Override
public String toString() {
return ReflectionToStringBuilder.toString(this, ToStringStyle.MULTI_LINE_STYLE);
}
}
@Entity
@Table(name = "t_classroom")
public class Classroom {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@Column(name = "name")
private String name;
/**
* 一个教室里面有多个学生,因此用到了OneToMany注解,所以Classroom实体类中就有了一个学生的集合属性。
* 集合就是多个值组成的属性,因此通过JoinColumn来定义一个外键的方式就行不通了。
*
* 这里通过OneToMany.mappedBy来指出集合(students)中每一个元素(student)的classroom属性,通过classroom属性
* 来连接(或称为映射)一个教室和多个学生之间的关系。
*
* 通过JsonIgnoreProperties注解避免出现序列化时候的死循环
*/
@OneToMany(mappedBy="classroom")
@JsonIgnoreProperties(value="classroom")
private List<Student> students;
}
_