MyBatis的collection和association的使用解讀
寫在前面
MyBatis涉及到多表關聯(lián)查詢的時候,有一個非常實用的工具,可以無縫封裝object、array,將結(jié)果返回指定格式的json數(shù)據(jù)。
在這里提供手把手教學,一起看collection和association如何使用。
表結(jié)構及數(shù)據(jù)準備
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;
數(shù)據(jù)與關系
分別在三張表中簡單的創(chuàng)建了幾條數(shù)據(jù),來簡單的表示數(shù)據(jù)之間的關系。

我們可以看出,school與class的數(shù)據(jù)之間是一對多的關系;class與teacher之間的關系是一對一的關系。
如果只是單純的使用sql關聯(lián)查詢時,會查出來三條數(shù)據(jù),其中school的數(shù)據(jù)是重復的,因為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這里省略了,我們直接調(diào)用SchoolMapper.xml中的list方法,查看一下執(zhí)行結(jié)果!
執(zhí)行結(jié)果

我們可以看到,class被封裝成了一個數(shù)組(因為我們在SchoolMapper.xml中用collection封裝);
teacher被封裝成一個對象(因為我們在ClassMapper.xml中用association封裝)。
總結(jié)
MyBatis提供了非常強大的對象、數(shù)組封裝方式,直接將查詢出來的結(jié)果封裝成對應的格式。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Mybatis中collection和association的使用區(qū)別詳解
- mybatis利用association或collection傳遞多參數(shù)子查詢
- Mybatis之a(chǎn)ssociation和collection用法
- 在Mybatis中association標簽多層嵌套的問題
- mybatis中一對一關系association標簽的使用
- MyBatis中association的基本使用方法
- mybatis的association傳遞參數(shù)問題示例
- Mybatis中一對多(collection)和一對一(association)的組合查詢使用
- mybatis中association標簽的使用解讀
- MyBatis使用嵌套查詢collection和association的實現(xiàn)
- Mybatis的association使用子查詢結(jié)果錯誤的問題解決
相關文章
Java將Word文檔轉(zhuǎn)換為PDF文件的幾種常用方法總結(jié)
這篇文章主要介紹了Java將Word文檔轉(zhuǎn)換為PDF文件的四種常用方法,分別使用ApachePOI+iText、Aspose.Words?for?Java、Docx4j和JODConverter,這些庫各有優(yōu)點,但在使用時需要注意庫與Java環(huán)境的兼容性、安裝所需依賴、轉(zhuǎn)換速度和資源消耗,需要的朋友可以參考下2024-10-10
HashMap原理及手寫實現(xiàn)部分區(qū)塊鏈特征
這篇文章主要為大家介紹了HashMap原理及手寫實現(xiàn)部分區(qū)塊鏈特征,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09

