学习内容:


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(Student student);
// 往中间表插入关系数据
void insertRelation(@Param("teacherId")Long teacherId, @Param("studentId")Long studentId);
}
  • StudentMapper.xml 文件
<!--
useGeneratedKeys=true 获取数据库保存数据的的主键值
keyProperty="id" 主键设置设置对象的 id 属性
-->
<insert id="save" useGeneratedKeys="true" keyProperty="id">
INSERT INTO student(name) VALUES(#{name})
</insert>
<insert id="insertRelation">
INSERT INTO teacher_student(teacher_id, student_id) VALUES (#{teacherId}, # {studentId})
</insert>

1.5、编写单元测试类

public class Many2manyTest {
@Test
public void testSave() throws Exception {
Teacher teacher1 = new Teacher();
teacher1.setName("波老师");
Teacher teacher2 = new Teacher();
teacher2.setName("罗老师");
Student s1 = new Student();
s1.setName("小强");
Student s2 = new Student();
s2.setName("小红");
s1.getTeachers().add(teacher1);
s1.getTeachers().add(teacher2);
// s1 被两个老师交了
s2.getTeachers().add(teacher1);
s2.getTeachers().add(teacher2);
// s2 被两个老师交了
SqlSession session = MyBatisUtil.getSession();
TeacherMapper teacherMapper = session.getMapper(TeacherMapper.class);
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
teacherMapper.save(teacher1);
teacherMapper.save(teacher2);
studentMapper.save(s1);
studentMapper.save(s2);
// 往中间表存入数据老师教学生的关系数据
for (Teacher t : s1.getTeachers()) {
studentMapper.insertRelation(t.getId(), s1.getId());
}
for (Teacher t : s2.getTeachers()) {
studentMapper.insertRelation(t.getId(), s2.getId());
}
session.commit();
session.close();
}
}

2. 单向多对多之额外 SQL 查询

2.1、需求

根据 id 查询学生,并查询其老师。

2.2、需要添加 Mapper 接口 和 Mapper XML

  • StudentMapper 接口
package com.yy.mapper;
public interface StudentMapper {
Student get(Long id);
}
  • StudentMapper.xml 文件
<resultMap type="Student" id="baseResultMap">
<id column="id" property="id"/>
<result column="name" property="name"/>
<!-- 关联属性,让 MyBatis 发额外 SQL -->
<collection select="cn.wolfcode.mapper.TeacherMapper.queryByStudentId" column="id" property="teachers"/>
</resultMap>
<select id="get" resultMap="baseResultMap">
SELECT id, name FROM student WHERE id = #{id}
</select>
  • TeacherMapper XML
package com.yy.mapper;
public interface queryByStudentId {
Teacher get(Long id);
}
  • TeacherMapper.xml 文件
<select id="queryByStudentId" resultType="Teacher">
SELECT t.id, t.name
FROM teacher_student ts
JOIN teacher t ON ts.teacher_id = t.id
WHERE ts.student_id = #{studentId}
</select>

2.3、单元测试方法

public class Many2oneTest {
@Test
public void testGet() throws Exception {
SqlSession session = MyBatisUtil.getSession();
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
Student student = studentMapper.get(2L);
System.out.println(student); session.close();
}
}

总结:

以上就是使用 Mybatis 多表实现多对多查询、添加操作了,代码仅供参考,欢迎讨论交流。

Mybatis 多表实现多对多查询、添加操作的更多相关文章

  1. Mybatis 多表实现多对一查询、添加操作

    Mybatis 多表实现多对一查询.添加操作 学习内容: 1. 多对一之添加操作 1.1.需求 1.2.数据库表(多对一或一对多,数据库外键都是设置在多的一方) 1.3.类设计 1.4.Mapper ...

  2. hibernate之关于使用连接表实现多对一关联映射

    [Hibernate]之关于使用连接表实现多对一关联映射 在我们项目使用中採用中间表最多的一般就是多对一,或者是多对多,当然一对一使用中间表也是能够的,可是这样的几率通常少之又少!所以这里重点介绍多对 ...

  3. mybatis(一、原理,一对多,多对一查询)

    MyBatis框架及原理分析 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转换 ...

  4. MyBatis多对多查询

    -------------------siwuxie095                                 MyBatis 多对多查询         以订单和商品为例,即 一个订单可 ...

  5. mybatis学习记录六——一对一、一对多和多对多查询

    9       订单商品数据模型 9.1     数据模型分析思路 1.每张表记录的数据内容 分模块对每张表记录的内容进行熟悉,相当 于你学习系统 需求(功能)的过程. 2.每张表重要的字段设置 非空 ...

  6. MyBatis 高级查询之多对多查询(十一)

    高级查询之多对多查询 查询条件:根据玩家名,查询游戏信息 我们在之前创建的映射器接口 GameMapper.java 中添加接口方法,如下: /** * 根据玩家名查询游戏 * @param name ...

  7. mybatis 一对多和多对一关联查询

    首先  数据库量表之间字段关系(没有主外键) studentmajor表的id字段对应student表里major字段 两个实体类 package com.model; import java.uti ...

  8. SpringBoot使用Mybatis注解进行一对多和多对多查询(2)

    SpringBoot使用Mybatis注解进行一对多和多对多查询 GitHub的完整示例项目地址kingboy-springboot-data 一.模拟的业务查询 系统中的用户user都有唯一对应的地 ...

  9. mybatis由浅入深day02_4多对多查询_多对多查询总结

    4 多对多查询 4.1 需求(查询用户及用户购买商品信息) 查询用户及用户购买商品信息. 4.2 sql语句 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关 ...

随机推荐

  1. 论文翻译:2020_DCCRN: Deep Complex Convolution Recurrent Network for Phase-Aware Speech Enhancement

    论文地址:DCCRN:用于相位感知语音增强的深度复杂卷积循环网络 论文代码:https://paperswithcode.com/paper/dccrn-deep-complex-convolutio ...

  2. laravel7 验证器的使用

    $validator=\Validator::make($request->all(),[ 'username'=>'required', 'password'=>'required ...

  3. tp5 ajax单文件上传

    HTML代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  4. hive从入门到放弃(二)——DDL数据定义

    前一篇文章,介绍了什么是 hive,以及 hive 的架构.数据类型,没看的可以点击阅读:hive从入门到放弃(一)--初识hive 今天讲一下 hive 的 DDL 数据定义 创建数据库 CREAT ...

  5. MacOS新功能“通用控制”,多台设备操作互联太方便了!

    昨天看到macOS推送了12.3的更新,记得之前预告过一个"通用控制"的功能,所以赶紧升级一波体验一下,效果惊艳到我了,赶紧安利一波! 先交代一下现在隔离在家的办公情况,我主要是用 ...

  6. Net中委托之一

    1.委托的用法 委托是一种特殊的类型 a. 委托可以类外定义,也可以在类里面定义 b. 委托的操作步骤 1.委托的声明 2.委托的实例化 3.委托的调用 2.委托实例 amespace MyDeleg ...

  7. Linux 环境下安装 Nexus 私服存储库

    镜像下载.域名解析.时间同步请点击阿里云开源镜像站 一.nexus私服存储库简介 Nexus 是一个强大的maven仓库管理器,它极大地简化了本地内部仓库的维护和外部仓库的访问.,还可以用来创建yum ...

  8. C# 将CSV转为Excel

    CSV(Comma Separated Values)文件是一种纯文本文件,包含用逗号分隔的数据,常用于将数据从一个应用程序导入或导出到另一个应用程序.通过将CSV文件转为EXCEL,可执行更多关于数 ...

  9. 『忘了再学』Shell基础 — 3、echo命令的介绍与使用

    目录 1.echo命令的作用 2.echo命令的基本用法 3.echo命令的-e选项用法 4.echo命令一些特殊用法 (1)输出字符带有字体颜色 (2)输出字符带有背景颜色 在讲Shell脚本之前, ...

  10. loj#6072 苹果树(折半搜索,矩阵树定理,容斥)

    loj#6072 苹果树(折半搜索,矩阵树定理,容斥) loj 题解时间 $ n \le 40 $ . 无比精确的数字. 很明显只要一个方案不超过 $ limits $ ,之后的计算就跟选哪个没关系了 ...