学习内容:


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. 递归——深度优先搜索(DFS)——以滑雪问题为例(自顶而下)

    一.问题:滑雪 问题描述:小明喜欢滑雪,为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.小明想知道在一个区域中最长底滑坡.区域由一个二维数组给出.数组的每 ...

  2. 【二】遗传算法(GA)的MATLAB实现

    essay from:https://wenku.baidu.com/view/ce45bbf44693daef5ef73df3.html 一.MATLAB编程实现GA 二.MATLAB函数调用实现G ...

  3. laravel 根据字段不同值做不同查询

    在开发过程中我们经常遇到这种情况: 例如,一个信息表message,字段type 1.操作提醒 2.平台通知,表message_read记录当信息是平台通知时用户浏览状况 那么 当信息是平台通知时是针 ...

  4. 分布式 PostgreSQL 集群(Citus)官方示例 - 多租户应用程序实战

    如果您正在构建软件即服务 (SaaS) 应用程序,您可能已经在数据模型中内置了租赁的概念. 通常,大多数信息与租户/客户/帐户相关,并且数据库表捕获这种自然关系. 对于 SaaS 应用程序,每个租户的 ...

  5. 关于C#窗体应用程序的一点总结

    1.在窗体Form在Form_Load函数中写了过多的界面初始化语句导致界面卡顿时 解决方法为:将一些初始化语句写在public Form()函数中,会大大加快程序的初始化加载速度. 2.为butto ...

  6. IDEA版部署离线ArcGIS api for JavaScript

    痛苦!折磨! 这两天发现IDEA 做ArcGIS api 开发比EClipse好用(重点是没有JS提示).但引入的ArcGIS api 一直报错,说找不到.这两天思来想去就是不知道为什么找不到loca ...

  7. django之分页,纯python代码

    Django中分页 py文件代码 """ 自定义分页组件 可以返回分页的数据和分页的HTML代码 """ from django.http ...

  8. python练习册 每天一个小程序 第0005题

    1 # -*-coding:utf-8-*- 2 __author__ = 'Deen' 3 ''' 4 题目说明: 你有一个目录,装了很多照片,把它们的尺寸变成都不大于 iPhone5 分辨率的大小 ...

  9. WebGL 的 Hello World

    本文整理自 div 侠于 凹凸 2022 年技术分享,简单介绍了 WebGL 画一个基础图形的流程,希望你了解之后,在使用 3d 渲染库的时候可以少点迷糊. 四种常用的页面绘图工具 关于h5页面的图形 ...

  10. loj536「LibreOJ Round #6」花札(二分图博弈)

    loj536「LibreOJ Round #6」花札(二分图博弈) loj 题解时间 很明显是二分图博弈. 以某个点为起点,先手必胜的充要条件是起点一定在最大匹配中. 判断方法是看起点到该点的边有流量 ...