mybatis plus 一对多,多表联查的使用小记
阅读本博文需要有基础的mybatis以及mybatis plus知识,如果没有建议您了解相关的内容
本项目使用的是springboot构建的,数据库字段命名不严谨仅做演示测试使用,本文不做相关源码的解析只做功能使用讲解
相对于mybatis来说 plus用起来真的很舒服,单表查询crud,以及分页功能真的如丝般顺滑,使用方法就不再一一赘述献丑了,因为查询了很多资料各种方法都有甚至可以使用注解来进行查询,但是我认为这样不便于管理,因此没有找到对我有用的相关连表,关联查询的方法,所以自己只能退而求次用mybatis的原始方法来做连表查询仅供参考,如果您有更好的特别欢迎您分享。
本篇文章讲的是如何来做一对多关系的查询,使用的是xml来配置相关查询语句。
我们单表查询的时候BaseMapper<T>基本的功能都实现了,同时mybatis plus的条件构造器QueryWrapper 可以帮助我们构建各种条件,如果特别复杂那就得手写了。
以学生,老师为例老师对学生为一对多,学生对老师也是一对多(这里只做老师的例子)
我的实体实现了Serializable接口这个看你个人的需求,在这里我重写了toString 方法,目的是做测试打印的,实际开发当中作为一个有工作经验的coder来说肯定知道不要重写tostring
老师实体的第4行代码代码我注释了,具体原因后续会讲。
1 @TableName(value = "sys_teacher")
2 public class Teacher implements Serializable {
3 @TableId(value = "pk_id" ,type = IdType.AUTO)
4 // @TableField(value = "pk_id")
5 private long id;
6 @TableField(value = "t_name")
7 private String name;
8 private String sex;
9 private String position;
10 @TableField(exist = false)
11 private List<Student> studentList;
12
13
14 public Teacher() {
15 }
16
17 public long getId() {
18 return id;
19 }
20
21 public void setId(long id) {
22 this.id = id;
23 }
24
25 public String getName() {
26 return name;
27 }
28
29 public void setName(String name) {
30 this.name = name;
31 }
32
33 public String getSex() {
34 return sex;
35 }
36
37 public void setSex(String sex) {
38 this.sex = sex;
39 }
40
41 public String getPosition() {
42 return position;
43 }
44
45 public void setPosition(String position) {
46 this.position = position;
47 }
48
49 @Override
50 public String toString() {
51 return "Teacher{" +
52 "id=" + id +
53 ", name='" + name + '\'' +
54 ", sex='" + sex + '\'' +
55 ", position='" + position + '\'' +
56 ", studentList=" + studentList +
57 '}';
58 }
59 }
学生实体
1 @TableName(value = "sys_student")
2 public class Student implements Serializable {
3 @TableId(type = IdType.AUTO)
4 private long id;
5
6 private String name;
7 private String sex;
8 @TableField(value = "class_no")
9 private String classNo;
10 private int grade;
11
12 public Student() {
13 }
14
15 public int getGrade() {
16 return grade;
17 }
18
19 public void setGrade(int grade) {
20 this.grade = grade;
21 }
22
23 public long getId() {
24 return id;
25 }
26
27 public void setId(long id) {
28 this.id = id;
29 }
30
31 public String getName() {
32 return name;
33 }
34
35 public void setName(String name) {
36 this.name = name;
37 }
38
39 public String getSex() {
40 return sex;
41 }
42
43 public void setSex(String sex) {
44 this.sex = sex;
45 }
46
47 public String getClassNo() {
48 return classNo;
49 }
50
51 public void setClassNo(String classNo) {
52 this.classNo = classNo;
53 }
54
55 @Override
56 public String toString() {
57 return "Student{" +
58 "id=" + id +
59 ", name='" + name + '\'' +
60 ", sex='" + sex + '\'' +
61 ", classNo='" + classNo + '\'' +
62 ", grade=" + grade +
63 '}';
64 }
65 }
数据库截图

老师表

学生表

中间表

在这里我们需要查询老师多对应的学生列表,因为数据库字段里面不包含学生,如果单独查询老师我使用了@TableField(exist = false) 不让属性名作为数据库字段查询,否则映射会出错
具体错误我就 不再演示了,下面是.xml的配置以教师的xml来举栗子,大家可以看到,这里的配置其实和mybatis一样,如果使用xml配置,字段名和属性名一致可以 不做配置,如果不一样那么就必须做关系映射
1 <?xml version="1.0" encoding="UTF-8" ?>
2 <!DOCTYPE mapper
3 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
4 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
5 <mapper namespace="com.ls.springboot.mp.mapper.ITeacherMapper">
6 <resultMap id="teacherRM" type="Teacher">
7 <id property="id" column="pk_id"/>
8 <!--<result property="name" column="name"/>
9 <result property="sex" column="sex"/>
10 <result property="position" column="position"/>-->
11
12 <collection property="studentList" column="pk_id" select="findStudentListById"></collection>
13 </resultMap>
14 这是关联查询的sql和mybatis一样
15 <select id="findInfo" resultMap="teacherRM">
16
17 select * from sys_teacher
18 </select>
19 <select id="findStudentListById" parameterType="int" resultType="Student">
20
21 SELECT s.* from sys_teacher_student m LEFT JOIN sys_student s
22 on s.id=m.student_id WHERE m.teacher_id=#{id}
23 </select>
24 </mapper>
这里和mybatis的查询方式一样,8-10行注释的地方表示可以省略,如果实体的属性名和数据库表的字段不一致那么在xml里面就不能省略否则出现无法映射的情况
例如在xml未做name的映射则会出现这样的情况

而加上
<result property="name" column="t_name"/>
则会完成映射,我们使用单表查询的时候是不用考虑映射的情况plus会自动去映射

至于为什么要在xml里配置 <id property="id" column="pk_id"/>,因为如果不做配置的话 做连表查询的时候会将id传给studentList,而实体本身就不能获取到id了
1 <!--<id property="id" column="pk_id"/>-->
2 注释掉之后 查看结果

如果恢复的话则可以完全查出相应的内容

3 @TableId(value = "pk_id" ,type = IdType.AUTO)
4 // @TableField(value = "pk_id")
由于我没有仔细去阅读相关文档,在做主键的字段映射的时候以为TableId 和 TableField 可以同时使用,
结果在后续的测试当中发现两者不能同时使用,即使使用之后TableField 也不会起作用,因为@TableId提供了value 的属性 ,这是慕课老师的解答印证了我的观点

mybatis plus 一对多,多表联查的使用小记的更多相关文章
- Mybatis学习——一对多关联表查询
1.实体类 public class Student { private int id; private String name; } public class Classes { private i ...
- mybatis-plus注解版实现多表联查(sql)
mybatis注解版实现多表联查 需求: 用户有角色,角色有权限,需要一次取用户信息包含角色信息及其对应权限 实体类: package cn.zytao.taosir.common.model.use ...
- 【mybatis】mybatis多表联查,存在一对多关系的,实体中使用List作为字段接收查询结果的写法
实体如下: IntegralGoods 积分商品 IntegralGoodsImg 积分商品图片 ShelfLog 积分商品自动上架记录 IntegralGoods :IntegralGoodsIm ...
- Mybatis中多表联查,查询出来的字段出现重名,造成数据异常的解决方法!
在做一对多出现的问题,引发的思考:当数据库表中,主表的主键id和明细表的中的字段名相同时怎么办?Mybatis进行自动映射赋值的时候会不会出现异常? 注意:M ...
- mybatis.net 多表联查
mybatis.net针对多表联查,其实不用讲联查出的所有的列全部做一个新的resultMap,我们完全可以通过集成关系来实现,真是上一次说的懒加载,在一定程度上可以提高其性能,但这并不是说懒加载性能 ...
- 使用mybatis多表联查的时候结果异常及springmvc的理解
今天使用mybatis多表联查的时候,在dos窗口查询时可以出结果集,但是使用mybatis查询的时候最后返回的结果只有最后一个结果 然后研究了半天没弄出来,后来无意中发现添加了最外层从表的ID字段后 ...
- mybatis的一对多,多对一,以及多对对的配置和使用
1.本文章是无意中看见易百教程的Mybatis教程才注意到这个问题,平时都仅仅是在用CRUD,忽略了这方面的问题,真实十分羞愧 2.首先我们开始对mybatis的一对多的探究 根据这个应用场景 ...
- Mybatis基于注解实现多表查询
对应的四种数据库表关系中存在四种关系:一对多,多对应,一对一,多对多.在前文中已经实现了xml配置方式实现表关系的查询,本文记录一下Mybatis怎么通过注解实现多表的查询,算是一个知识的补充. 同样 ...
- mybatis进阶案例之多表查询
mybatis进阶案例之多表查询 一.mybatis中表之间的关系 在数据库中,实体型之间的关系主要有如下几种: 1.一对一 如果对于实体集A中的每一个实体,实体集B中至多有一个(也可以没有)实体与之 ...
随机推荐
- C#综合细说进程、应用程序域与上下文
引言 本文主要是介绍进程(Process).应用程序域(AppDomain)..NET上下文(Context)的概念与操作. 虽然在一般的开发当中这三者并不常用,但熟悉三者的关系,深入了解其作用,对提 ...
- Python环境变量配置
第一步:下载Python安装包 在Python的官网 www.python.org 中找到最新版本的Python安装包,点击进行下载,请注意,当你的电脑是32位的机器,请选择32位的安装包,如果是64 ...
- MySql 文件导入导出
1.将表输出到文件 select * FROM zhilianzhaopin4 INTO OUTFILE 'G:/test.csv' --------输出位置 fields terminat ...
- Linkerd 2.10(Step by Step)—配置超时
Linkerd 2.10 系列 快速上手 Linkerd v2 Service Mesh(服务网格) 腾讯云 K8S 集群实战 Service Mesh-Linkerd2 & Traefik2 ...
- Git使用教程七——Git实用技能
Git实用技能 1.图形管理工具 Github for Desktop Source tree 老牌的GitGUl管理工具了,也号称是最好用的Git GUI工具.功能丰富,基本操作和高 级操作都非常流 ...
- RabbitMQ从零到集群高可用(.NetCore5.0) -高可用集群构建落地
系列文章: RabbitMQ从零到集群高可用(.NetCore5.0) - RabbitMQ简介和六种工作模式详解 RabbitMQ从零到集群高可用(.NetCore5.0) - 死信队列,延时队列 ...
- 学习笔记之IdentityServer4(一)
快速入门IdentityServer4 概述 将 IdentityServer 添加到 ASP.NET Core 应用程序 配置 IdentityServer 为各种客户发行代币 保护 Web 应用程 ...
- 手动编译部署LNMP环境(CentOS7.5+Nginx-1.18.0+MySQL-5.7.30+PHP-7.4.14)
在平时运维工作中,经常需要用到LNMP应用框架.LNMP环境是指在Linux系统下,由Nginx + MySQL + PHP组成的网站服务器架构. 可参考前面的文章: 如何在CentOS 7上搭建LA ...
- 云效x钉钉:让研发工作更简单
云效x钉钉:让研发工作更简单,奔走相告,云效&钉钉集成实现组织架构.成员同步以及消息通知啦! 我们知道云效致力于智能化.安全可追溯.高效.简单.灵活,「云效新一代企业级DevOps平台」阿里云 ...
- 经典多级时间轮定时器(C语言版)
经典多级时间轮定时器(C语言版) 文章目录 经典多级时间轮定时器(C语言版) 1. 序言 2. 多级时间轮实现框架 2.1 多级时间轮对象 2.2 时间轮对象 2.3 定时任务对象 2.4 双向链表 ...