Java中MyBatis的結(jié)果映射詳解
一、 概述
Java 數(shù)據(jù)持久層實(shí)現(xiàn)了應(yīng)用程序與數(shù)據(jù)源的交互,大多數(shù)時(shí)候需要使用到各種查詢(xún)語(yǔ)句。
MyBatis 支持對(duì)各種單表查詢(xún)、關(guān)聯(lián)查詢(xún)等各種復(fù)雜查詢(xún)的結(jié)果進(jìn)行映射。
二、結(jié)果映射
resultMap 元素是 MyBatis 中最重要最強(qiáng)大的元素,大部分查詢(xún)語(yǔ)句返回的結(jié)果,都能通過(guò)簡(jiǎn)單的配置來(lái)返回映射的 Java 對(duì)象。
假設(shè)存在這樣一個(gè)實(shí)體模型,一個(gè)用戶(hù)對(duì)應(yīng)有一個(gè)基本信息和擴(kuò)展信息,對(duì)應(yīng)有多個(gè)地址。
簡(jiǎn)單講,用戶(hù)基本信息與用戶(hù)擴(kuò)展信息是一對(duì)一的關(guān)系,與用戶(hù)地址是一對(duì)多的關(guān)系。

創(chuàng)建實(shí)體類(lèi)和數(shù)據(jù)訪問(wèn)接口如下:
// 用戶(hù)基本信息實(shí)體
@Data
public class User {
private Long id;
private String name;
private String username;
private String password;
private Integer status;
private UserExt extend;
private List<Address> addresses;
}
// 用戶(hù)擴(kuò)展信息實(shí)體
@Data
public class UserExt {
private Long id;
private Long userId;
private String phone;
private String email;
}
// 用戶(hù)地址信息實(shí)體
@Data
public class Address {
private Long id;
private Long userId;
private String address;
}
// 用戶(hù)相關(guān)接口
public interface UserExtMapper {
// 查詢(xún)用戶(hù)基本信息
User selectById(Long id);
// 查詢(xún)用戶(hù)基本信息和擴(kuò)展信息(一對(duì)一)
User selectExt(Long id);
// 查詢(xún)用戶(hù)基本信息和地址信息(一對(duì)多)
User selectAddresses(Long id);
}1. 基本映射
基本映射是對(duì)查詢(xún)返回的結(jié)果映射成一個(gè)最簡(jiǎn)單的 JavaBean 類(lèi),通過(guò)類(lèi)屬性對(duì)應(yīng)數(shù)據(jù)庫(kù)字段進(jìn)行映射。
<id> 和 <result> 元素都將列映射到一個(gè)簡(jiǎn)單的數(shù)據(jù)類(lèi)型(String, int, double 等)的屬性或字段。
其中的 property 對(duì)應(yīng) Java 類(lèi) 屬性名稱(chēng),column 對(duì)應(yīng)數(shù)據(jù)庫(kù)列名稱(chēng)。
<mapper namespace="cn.codeartist.mybatis.mapper.UserExtMapper">
<resultMap id="baseMap" type="User">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="status" column="status"/>
</resultMap>
<select id="selectById" resultMap="baseMap">
SELECT * FROM t_user WHERE id = #{id}
</select>
</mapper>2. 關(guān)聯(lián)映射
關(guān)聯(lián)映射是對(duì)查詢(xún)返回的結(jié)果映射成一對(duì)一關(guān)系的嵌套類(lèi),例如查詢(xún)同時(shí)返回用戶(hù)基本信息和用戶(hù)擴(kuò)展信息。
使用 <association> 元素來(lái)指定關(guān)聯(lián)映射,它可以映射一個(gè)關(guān)聯(lián)查詢(xún)語(yǔ)句的結(jié)果,也可以映射兩個(gè)查詢(xún)語(yǔ)句結(jié)合返回復(fù)雜的類(lèi)型。
其中的 property 對(duì)應(yīng)主表類(lèi)型的屬性,column 對(duì)應(yīng)主表關(guān)聯(lián)字段,javaType 對(duì)應(yīng)關(guān)聯(lián)表類(lèi)型,select 對(duì)應(yīng)另一個(gè)查詢(xún)語(yǔ)句。
如果映射一個(gè)關(guān)聯(lián)語(yǔ)句的結(jié)果,則不會(huì)使用 select 屬性。
<mapper namespace="cn.codeartist.mybatis.mapper.UserExtMapper">
<resultMap id="associationMap" type="User">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="status" column="status"/>
<association property="extend" column="id" javaType="UserExt" select="selectUserExtById">
<id property="id" column="id"/>
<result property="userId" column="user_id"/>
<result property="phone" column="phone"/>
<result property="email" column="email"/>
</association>
</resultMap>
<select id="selectExt" resultMap="associationMap">
SELECT * FROM t_user WHERE id = #{id}
</select>
<select id="selectUserExtById" resultType="UserExt">
SELECT * FROM t_user_ext WHERE user_id = #{id}
</select>
</mapper>3. 集合映射
集合映射是對(duì)查詢(xún)返回的結(jié)果映射成一對(duì)多關(guān)系的嵌套類(lèi),例如查詢(xún)同時(shí)返回用戶(hù)信息和用戶(hù)的地址信息。
使用 <collection> 元素來(lái)指定集合映射,它可以映射一個(gè)關(guān)聯(lián)查詢(xún)語(yǔ)句的結(jié)果,也可以映射兩個(gè)查詢(xún)語(yǔ)句結(jié)合返回復(fù)雜的類(lèi)型。
它的用法與關(guān)聯(lián)查詢(xún) <association> 類(lèi)似,只不過(guò)指定關(guān)聯(lián)表類(lèi)型需要使用 ofType 屬性,為了區(qū)分集合存儲(chǔ)的類(lèi)型。
<mapper namespace="cn.codeartist.mybatis.mapper.UserExtMapper">
<resultMap id="collectionMap" type="User">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="status" column="status"/>
<collection property="addresses" column="id" ofType="Address" select="selectAddressById">
<id property="id" column="id"/>
<result property="userId" column="user_id"/>
<result property="address" column="address"/>
</collection>
</resultMap>
<select id="selectAddresses" resultMap="collectionMap">
SELECT * FROM t_user WHERE id = #{id}
</select>
<select id="selectAddressById" resultType="Address">
SELECT * FROM t_address WHERE user_id = #{id}
</select>
</mapper>同時(shí)指定集合類(lèi)型和 Java 類(lèi)型:
<collection property="addresses" javaType="ArrayList" column="id" ofType="Address" select="selectAddressById"/>
4. 自動(dòng)映射
MyBatis 支持在簡(jiǎn)單的場(chǎng)景下,可以自動(dòng)映射結(jié)果,在復(fù)雜的場(chǎng)景下,只需描述語(yǔ)句之間的關(guān)系就行。
當(dāng)配置自動(dòng)映射結(jié)果時(shí),數(shù)據(jù)庫(kù)列名與 Java 類(lèi)屬性名稱(chēng)會(huì)忽略大小寫(xiě)映射,例如 ID 列會(huì)和 id 屬性進(jìn)行映射。
通常數(shù)據(jù)庫(kù)列名使用下劃線規(guī)范,而 Java 屬性遵循駝峰命名,將 mapUnderscoreToCamelCase 設(shè)置為 true 時(shí),會(huì)啟用自動(dòng)映射。
例如前面的基本映射、關(guān)聯(lián)映射和集合映射可以簡(jiǎn)化成下面配置:
<mapper namespace="cn.codeartist.mybatis.mapper.UserExtMapper">
<resultMap id="associationMap" type="User">
<association property="extend" column="id" javaType="UserExt" select="selectUserExtById"/>
</resultMap>
<resultMap id="collectionMap" type="User">
<collection property="addresses" column="id" ofType="Address" select="selectAddressById"/>
</resultMap>
<select id="selectById" resultType="User">
SELECT * FROM t_user WHERE id = #{id}
</select>
<select id="selectExt" resultMap="associationMap">
SELECT * FROM t_user WHERE id = #{id}
</select>
<select id="selectUserExtById" resultType="UserExt">
SELECT * FROM t_user_ext WHERE user_id = #{id}
</select>
<select id="selectAddresses" resultMap="collectionMap">
SELECT * FROM t_user WHERE id = #{id}
</select>
<select id="selectAddressById" resultType="Address">
SELECT * FROM t_address WHERE user_id = #{id}
</select>
</mapper>到此這篇關(guān)于Java中MyBatis的結(jié)果映射詳解的文章就介紹到這了,更多相關(guān)MyBatis的結(jié)果映射內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MyBatis延遲加載、關(guān)聯(lián)查詢(xún)與結(jié)果映射的實(shí)現(xiàn)原理解析
- 深度分析MybatisPlus查詢(xún)結(jié)果映射失敗@TableField失效解決辦法
- MyBatis 結(jié)果映射的兩種方式
- MyBatis結(jié)果映射(ResultMap)的使用
- MyBatis動(dòng)態(tài)SQL、模糊查詢(xún)與結(jié)果映射操作過(guò)程
- MyBatis中的SQL映射文件配置結(jié)果映射的操作指南
- 關(guān)于MyBatis結(jié)果映射的實(shí)例總結(jié)
- 基于mybatis查詢(xún)結(jié)果映射不到對(duì)象的處理
- MyBatis 結(jié)果映射的幾種實(shí)現(xiàn)方式
相關(guān)文章
SpringMVC異常處理知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于SpringMVC異常處理相關(guān)知識(shí)點(diǎn)內(nèi)容,需要的朋友們學(xué)習(xí)下。2019-10-10
Java使用Spring Batch處理大規(guī)模數(shù)據(jù)的實(shí)踐分享
在處理大規(guī)模數(shù)據(jù)的場(chǎng)景中,批處理是一個(gè)非常常見(jiàn)且必要的操作,Java中的Spring Batch是一個(gè)強(qiáng)大的框架,能夠幫助我們高效地執(zhí)行復(fù)雜的批處理任務(wù),本文將帶大家了解如何使用Spring Batch處理大規(guī)模數(shù)據(jù),并通過(guò)代碼示例展示如何實(shí)現(xiàn)高效的批處理,需要的朋友可以參考下2024-10-10
Java參數(shù)校驗(yàn)@Validated、@Valid介紹及使用詳解
Javax.validation是?spring?集成自帶的一個(gè)參數(shù)校驗(yàn)接口,可通過(guò)添加注解來(lái)設(shè)置校驗(yàn)條件,這篇文章主要介紹了Java參數(shù)校驗(yàn)@Validated、@Valid介紹及使用詳解,需要的朋友可以參考下2024-08-08
Java調(diào)用GPU算力的實(shí)現(xiàn)示例
本文主要介紹了Java調(diào)用GPU算力的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-03-03
java實(shí)現(xiàn)簡(jiǎn)單銀行ATM系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單銀行ATM系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
SpringBoot結(jié)合mockito測(cè)試實(shí)戰(zhàn)
與集成測(cè)試將系統(tǒng)作為一個(gè)整體測(cè)試不同,單元測(cè)試更應(yīng)該專(zhuān)注于某個(gè)類(lèi)。所以當(dāng)被測(cè)試類(lèi)與外部類(lèi)有依賴(lài)的時(shí)候,尤其是與數(shù)據(jù)庫(kù)相關(guān)的這種費(fèi)時(shí)且有狀態(tài)的類(lèi),很難做單元測(cè)試。但好在可以通過(guò)“Mockito”這種仿真框架來(lái)模擬這些比較費(fèi)時(shí)的類(lèi),從而專(zhuān)注于測(cè)試某個(gè)類(lèi)內(nèi)部的邏輯2022-11-11
SpringBoot使用注解進(jìn)行分頁(yè)的實(shí)現(xiàn)示例
分頁(yè)使用可以說(shuō)非常普遍了,有時(shí)候會(huì)需要非常靈活的方式去開(kāi)啟或關(guān)閉分頁(yè),嘗試使用一下注解的方式來(lái)進(jìn)行分頁(yè),本文主要介紹了SpringBoot使用注解進(jìn)行分頁(yè)的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
適用于Java初學(xué)者的學(xué)習(xí)路線圖
這篇文章主要介紹了學(xué)習(xí)Java的路線圖的五個(gè)必經(jīng)階段,還有一些作者的想法分享給大家,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09

