Mybatis 多表实现多对多查询、添加操作
学习内容:
1. 多对多之添加操作
1.1、需求
保存两个学生和两个老师,且这两个老师都教了这个两个学生。
1.2、数据库表(多对多数据库设计需要设计中间表)
- 表设计
1.3、类设计
- Teacher 实体类
package com.yy.domain;
@Setter
@Getter
@ToString
public class Teacher {
private Long id;
private String name;
}
- Employee 实体类
package com.yy.domain;
@Setter
@Getter
@ToString
public class Student {
private Long id;
private String name;
// 关联属性
private List<Teacher> teachers = new ArrayList<>();
}
1.4、Mapper 接口和 Mapper XML 文件编写
注意: Mapper XML 放置的位置是在 resources 目录下。
- TeacherMapper 接口
package com.yy.mapper;
public interface TeacherMapper {
void save(Teacher teacher);
}
- TeacherMapper.xml 文件
<!--
useGeneratedKeys=true 获取数据库保存数据的的主键值
keyProperty="id" 主键设置设置对象的 id 属性
-->
<insert id="save" useGeneratedKeys="true" keyProperty="id">
INSERT INTO teacher(name) VALUES(#{name})
</insert>
- StudentMapper 接口
package com.yy.mapper;
public interface StudentMapper {
void save