MyBatis的collection和association的使用解读

 更新时间:2023年12月27日 09:52:57   作者:秃了也弱了。  
这篇文章主要介绍了MyBatis的collection和association的使用解读

写在前面

MyBatis涉及到多表关联查询的时候,有一个非常实用的工具,可以无缝封装object、array,将结果返回指定格式的json数据。

在这里提供手把手教学,一起看collection和association如何使用。

表结构及数据准备

CREATE TABLE `test_school` (
  `id` varchar(20) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
 
CREATE TABLE `test_class` (
  `id` varchar(20) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `school_id` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
CREATE TABLE `test_teacher` (
  `id` varchar(20) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `class_id` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

数据与关系

分别在三张表中简单的创建了几条数据,来简单的表示数据之间的关系。

我们可以看出,school与class的数据之间是一对多的关系;class与teacher之间的关系是一对一的关系。

如果只是单纯的使用sql关联查询时,会查出来三条数据,其中school的数据是重复的,因为left join嘛。

关键:MyBatis的xml

SchoolMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.boot.security.server.dao.SchoolDao">
 
	<resultMap id="SchoolMap" type="com.boot.security.server.model.TestSchool">
		<id column="id" property="id" />
		<result column="name" property="name" />
		<collection property="testClasses" columnPrefix="tc_"
					resultMap="com.boot.security.server.dao.ClassDao.ClassMap"/>
	</resultMap>
 
	<select id="list" resultMap="SchoolMap">
		select ts.id,ts.name,
			tc.id AS tc_id,
			tc.name AS tc_name,
			tc.school_id AS tc_school_id,
			tt.id AS tc_tt_id,
			tt.name AS tc_tt_name,
			tt.class_id AS tc_tt_class_id
		from test_school ts
		left join test_class tc on ts.id=tc.school_id
		left join test_teacher tt on tc.id=tt.class_id
	</select>
 
</mapper>

ClassMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.boot.security.server.dao.ClassDao">
 
	<resultMap id="ClassMap" type="com.boot.security.server.model.TestClass">
		<id column="id" property="id" />
		<result column="name" property="name" />
		<result column="school_id" property="schoolId" />
		<association property="testTeacher" columnPrefix="tt_"
					 resultMap="com.boot.security.server.dao.TeacherDao.TeacherMap"/>
	</resultMap>
 
</mapper>

TeacherMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.boot.security.server.dao.TeacherDao">
 
	<resultMap id="TeacherMap" type="com.boot.security.server.model.TestTeacher">
		<id column="id" property="id" />
		<result column="name" property="name" />
		<result column="class_id" property="classId" />
	</resultMap>
 
</mapper>

注意!SchoolMapper.xml中的collection与ClassMapper.xml中的association!

注意!注意查询的sql起的别名,与collection和association中的columnPrefix属性需要对应

其中service、controller这里省略了,我们直接调用SchoolMapper.xml中的list方法,查看一下执行结果!

执行结果

我们可以看到,class被封装成了一个数组(因为我们在SchoolMapper.xml中用collection封装);

teacher被封装成一个对象(因为我们在ClassMapper.xml中用association封装)。

总结

MyBatis提供了非常强大的对象、数组封装方式,直接将查询出来的结果封装成对应的格式。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java中对象转json字符串的三种常用方式

    java中对象转json字符串的三种常用方式

    本文主要介绍了java中对象转json字符串的三种常用方式,包含Jackson库,Gson库和Hutool工具类这三种,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • JAVA(MAVEN项目)添加JUnit依赖配置全过程

    JAVA(MAVEN项目)添加JUnit依赖配置全过程

    在Maven项目中进行单元测试是确保代码质量的重要步骤,本教程提供SpringBoot和微服务平台适用的单元测试方法,包括环境准备、创建测试类、JUnit简介及注解使用,环境准备涉及引入依赖和安装JUnit插件,测试类创建可通过快捷键或手动添加@Test注解来实现
    2024-10-10
  • SpringBoot快速通关自动配置应用

    SpringBoot快速通关自动配置应用

    在进行项目编写前,我们还需要知道一个东西,就是SpringBoot对我们的SpringMVC还做了哪些配置,包括如何扩展,如何定制,只有把这些都搞清楚了,我们在之后使用才会更加得心应手
    2022-07-07
  • java中线程安全的list详细特性和用法

    java中线程安全的list详细特性和用法

    这篇文章主要给大家介绍了关于java中线程安全的list详细特性和用法的相关资料,Java中有多种线程安全的List,其中比较常用的有Vector、Collections.synchronizedList()和CopyOnWriteArrayList三种方式,需要的朋友可以参考下
    2024-03-03
  • Mybatis如何自动生成sql语句

    Mybatis如何自动生成sql语句

    这篇文章主要介绍了Mybatis如何自动生成sql语句,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • java经典问题:连个字符串互为回环变位

    java经典问题:连个字符串互为回环变位

    连个字符串互为回环变位经常出现在java程序员面试中,这个是考验程序员的解题思路和方法的最经典的一题,小编为大家详细分析一下,一起来学习吧。
    2017-11-11
  • 深入理解Java并发编程之LinkedBlockingQueue队列

    深入理解Java并发编程之LinkedBlockingQueue队列

    本文主要介绍了Java并发编程之LinkedBlockingQueue队列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Java 精炼解读类和对象原理

    Java 精炼解读类和对象原理

    面向对象乃是Java语言的核心,是程序设计的思想。Java语言的面向对象技术包括了面向对象和面向过程的基本概念,面向对象的特征,Java语言的类,对象,修饰符,抽象类等一系列的知识点
    2022-03-03
  • Java Optional的判空操作详解

    Java Optional的判空操作详解

    JAVA在1.8版本推出Optional,官方文档将其描述为可能包含或不包含非空值的容器对象,目前Optional用于避免程序出现异常NullPointerException,感兴趣的可以了解一下
    2022-09-09
  • 基于jenkins构建结果企业微信提醒

    基于jenkins构建结果企业微信提醒

    这篇文章主要介绍了基于jenkins构建结果企业微信提醒,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08

最新评论