mybatis多層嵌套resultMap及返回自定義參數(shù)詳解
1.兩層嵌套,一個list中加另外一個list
data:[
{a:123,b:456,c:[{d:7,e:8}]}
]
xml文件定義的sql
select * from zhy z LEFT JOIN wl w on z.id = w.zid
resultMap可以定義:
<resultMap id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wl自動生成的BaseResultMap"/> </resultMap>
如果測試表zhy與wl表中存在重復(fù)名稱的字段可以使用columnPrefix
注意w_
select z.*,w.b as w_b,w.c as w_c from zhy z LEFT JOIN wl w on z.id = w.zid
<resultMap id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wl自動生成的BaseResultMap" columnPrefix="w_"/> </resultMap>
如果接收的實體是自定義的實體并且還有默認(rèn)參數(shù)
當(dāng)resultMap返回的實體中存在默認(rèn)值的時候,發(fā)現(xiàn)外層的zhy是可以賦值成功的,但是內(nèi)層的wl卻沒有,這個時候需要將自動生成的BaseResultMap復(fù)制一份重新定義接收實體類
/**
* 比如這樣實體接收中存在默認(rèn)賦值
*
* @author zhy
*/
@EqualsAndHashCode(callSuper = true)
@Data
public class WlVo extends Wl {
/**
* 默認(rèn)賦值false
*/
private boolean select = false;
}
將type改為自定義的之后在引用
<resultMap id="wlBaseResultMap" type="com.yasugongshang.db.vo.WlVo"> <id column="id" jdbcType="BIGINT" property="id" /> <result column="a" jdbcType="BIGINT" property="a" /> </resultMap> <resultMap id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wlBaseResultMap" columnPrefix="w_"/> </resultMap>
2.三層嵌套,一個list中加另外一個list,內(nèi)list中還存在list
data:[
{a:123,b:456,c:[{d:7,e:8,f:[str]}]}
]
這時候只需要在內(nèi)層wlBaseResultMap中再增加一個collection即可
需要注意的是這個時候columnPrefix可能會導(dǎo)致數(shù)據(jù)為空
<resultMap id="wlBaseResultMap" type="com.yasugongshang.db.vo.WlVo"> <id column="id" jdbcType="BIGINT" property="id" /> <result column="a" jdbcType="BIGINT" property="a" /> <collection property="f" ofType="string"> <id column="f" jdbcType="VARCHAR"/> </collection> </resultMap>
補充知識:Mybatis中查詢返回多個對象使用resultType使用Map類型代替resultMap
查詢resultType直接使用Type,Dao層返回對象為List嵌套的一個Map數(shù)據(jù)結(jié)構(gòu)
List<Map<String,Object>> selectAll(); <select id="selectAll" resultType="Map"> //查詢語句 </select>
其中Map的key值為查詢的屬性,Object為查詢的值.
注:使用map類型無法轉(zhuǎn)換成駝峰命名,建議還是使用resultMap類型
以上這篇mybatis多層嵌套resultMap及返回自定義參數(shù)詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- mybatis-plus指定字段模糊查詢的實現(xiàn)方法
- springboot?+mybatis?使用PageHelper實現(xiàn)分頁并帶條件模糊查詢功能
- MyBatis中模糊查詢使用CONCAT('%',#{str},'%')出錯的解決
- Mybatis?mysql模糊查詢方式(CONCAT多個字段)及bug
- mybatis?使用concat?模糊查詢方式
- Java Fluent Mybatis 聚合查詢與apply方法詳解流程篇
- Mybatis insert方法主鍵回填和自定義操作
- 詳解MyBatis中主鍵回填的兩種實現(xiàn)方式
- Mybatis模糊查詢之三種定義參數(shù)方法和聚合查詢、主鍵回填實現(xiàn)方法
相關(guān)文章
解決spring-boot 打成jar包后 啟動時指定參數(shù)無效的問題
這篇文章主要介紹了解決spring-boot 打成jar包后 啟動時指定參數(shù)無效的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
java中數(shù)組的相關(guān)知識小結(jié)(推薦)
下面小編就為大家?guī)硪黄猨ava中數(shù)組的相關(guān)知識小結(jié)(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07
SpringMVC 跨重定向請求傳遞數(shù)據(jù)的方法實現(xiàn)
這篇文章主要介紹了SpringMVC 跨重定向請求傳遞數(shù)據(jù)的方法實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Java創(chuàng)建數(shù)組、賦值的四種方式詳解(聲明+創(chuàng)建+初始化?)
數(shù)組是一種數(shù)據(jù)結(jié)構(gòu),用來存儲同一類型值的集合一旦創(chuàng)建了數(shù)組,就不能再改變它的長度,下面這篇文章主要給大家介紹了關(guān)于Java創(chuàng)建數(shù)組、賦值的四種方式(聲明+創(chuàng)建+初始化?)的相關(guān)資料,需要的朋友可以參考下2024-04-04
SpringBoot3中數(shù)據(jù)庫集成實踐詳解
項目工程中,集成數(shù)據(jù)庫實現(xiàn)對數(shù)據(jù)的增曬改查管理,是最基礎(chǔ)的能力,所以下面小編就來和大家講講SpringBoot3如何實現(xiàn)數(shù)據(jù)庫集成,需要的可以參考下2023-08-08

