Mybatis 多表实现多对多查询、添加操作
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(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 多表实现多对多查询、添加操作的更多相关文章
- Mybatis 多表实现多对一查询、添加操作
Mybatis 多表实现多对一查询.添加操作 学习内容: 1. 多对一之添加操作 1.1.需求 1.2.数据库表(多对一或一对多,数据库外键都是设置在多的一方) 1.3.类设计 1.4.Mapper ...
- hibernate之关于使用连接表实现多对一关联映射
[Hibernate]之关于使用连接表实现多对一关联映射 在我们项目使用中採用中间表最多的一般就是多对一,或者是多对多,当然一对一使用中间表也是能够的,可是这样的几率通常少之又少!所以这里重点介绍多对 ...
- mybatis(一、原理,一对多,多对一查询)
MyBatis框架及原理分析 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转换 ...
- MyBatis多对多查询
-------------------siwuxie095 MyBatis 多对多查询 以订单和商品为例,即 一个订单可 ...
- mybatis学习记录六——一对一、一对多和多对多查询
9 订单商品数据模型 9.1 数据模型分析思路 1.每张表记录的数据内容 分模块对每张表记录的内容进行熟悉,相当 于你学习系统 需求(功能)的过程. 2.每张表重要的字段设置 非空 ...
- MyBatis 高级查询之多对多查询(十一)
高级查询之多对多查询 查询条件:根据玩家名,查询游戏信息 我们在之前创建的映射器接口 GameMapper.java 中添加接口方法,如下: /** * 根据玩家名查询游戏 * @param name ...
- mybatis 一对多和多对一关联查询
首先 数据库量表之间字段关系(没有主外键) studentmajor表的id字段对应student表里major字段 两个实体类 package com.model; import java.uti ...
- SpringBoot使用Mybatis注解进行一对多和多对多查询(2)
SpringBoot使用Mybatis注解进行一对多和多对多查询 GitHub的完整示例项目地址kingboy-springboot-data 一.模拟的业务查询 系统中的用户user都有唯一对应的地 ...
- mybatis由浅入深day02_4多对多查询_多对多查询总结
4 多对多查询 4.1 需求(查询用户及用户购买商品信息) 查询用户及用户购买商品信息. 4.2 sql语句 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关 ...
随机推荐
- java中的异常(Exception)
基本概念 将程序执行中发生的不正常的情况称为"异常".开发中的语法错误和逻辑错误不是异常 执行过程中的异常事件可分为两大类 错误(Error):Java虚拟机无法解决的严重问题.例 ...
- docker基础命令,常用操作
docker基础命令 使用docker镜像 获取镜像 从docker registry获取镜像的命令是docker pull.命令格式是: docker pull [选项][docker regist ...
- 解决使用DBeaver连接MySQL时报错-The server time zone value '�й���ʱ��' is unrecognized or represents more than one time zone.
解决使用DBeaver连接MySQL时报错,其实提示很明显. The server time zone value '�й���ʱ��' is unrecognized or represents ...
- 74CMS 3.0 SQL注入漏洞前台
一. 启动环境 1.双击运行桌面phpstudy.exe软件 2.点击启动按钮,启动服务器环境 二.代码审计 1.双击启动桌面Seay源代码审计系统软件 2.因为74CMS3.0源代码编辑使用GBK编 ...
- Golang 包了解以及程序的执行
Golang 包了解以及程序的执行 引言 Go 语言是使用包来组织源代码的,包(package)是多个 Go 源码的集合,是一种高级的代码复用方案.Go 语言中为我们提供了很多内置包,如 fmt.o ...
- Redis数据结构详解(1)-redis中的字符串(SDS)
前提知识 我们先从百科上摘下Redis的解释: Redis是一个使用ANSI C编写的开源.支持网络.基于内存.分布式.可选持久性的键值对存储数据库. (不用过多在意ANSI,它只是一个标准,你可以理 ...
- 数据库MySql的学习(1)--基本操作
转自 博客园-hoojo-http://www.cnblogs.com/hoojo/archive/2011/06/20/2085390.html 一.数据库简单介绍 1. 按照数据库的发展时间顺序, ...
- Spring 的优点?
(1)spring属于低侵入式设计,代码的污染极低: (2)spring的DI机制将对象之间的依赖关系交由框架处理,减低组件的耦合性: (3)Spring提供了AOP技术,支持将一些通用任务,如安全. ...
- mac-变量
去除每次都要source : 加入:
- Zookeeper 下 Server 工作状态?
服务器具有四种状态,分别是 LOOKING.FOLLOWING.LEADING.OBSERVING. 1.LOOKING:寻找 Leader 状态.当服务器处于该状态时,它会认为当前集群中没有 Lea ...