我们先来看看什么是多对多关系
常见的,在生活中会有学生对象以及老师对象.
一个老师可以同时有多个学生,一个学生也可以同时有多个老师,这就是一个典型的多对多场景
再来看看数据库中多对多关系的处理
数据库中对于多对多关系的处理,一般都是采用一个中间表来与之对应。
中间表中的数据一般就由两张表中的主键来决定
学生类以及老师类的简单设计
//学生类
public class Student{
private int stu_id;
private String stu_name;
private Set<Teacher> teacher_set;
//省去相应的set跟get方法
}
//老师类
public class Teacher{
private int tea_id;
private String tea_name;
private Set<Student> student_set;
//省去相应的set跟get方法
}
对应的映射文件
学生类的映射文件
<class name="Student" table="student">
<id name="stu_id">
<generator class="native"></generator>
</id>
<property name="stu_name"></property>
<set name="teacher_set" table="relation" cascade="save-update">
<key column="stuId"></key>
<many-to-many column="teaId" class="Teacher"></many-to-many>
</set>
</class>
老师类的映射文件
<class name="Teacher" table="teacher">
<id name="tea_id">
<generator class="native"></generator>
</id>
<property name="tea_name"></property>
<set name="student_set" table="relation" cascade="save-update">
<key column="teaId"></key>
<many-to-many column="stuId" class="Student"></many-to-many>
</set>
</class>
我们需要注意的就是两个文件中的set部分
这里为什么要用set来配置呢?
因为我们在类中存储多对象的方式是Set。如果用的是List,那就用list,如果是数组,就用array。
set中的各项参数说明
set中的值:
- name的值是实体类中的Set属性的属性名
- table的值是存储两个实体类之间的关系的表的名字
set下的key
- key中的column的值也就是关系表中的外键,他的值通常由该实体类中的主键来确定
set下的many-to-many
- 这下面的column通常是对应的另一个实体类的主键在关系表中的展示
- class则是另一个实体类的类型