Mybatis中注解@MapKey的使用詳解
mybatis的原身是ibatis,現(xiàn)在已經(jīng)脫離了apache基金會,新官網(wǎng)是http://www.mybatis.org/。
在研究Mybatis源碼之前并不知道這個(gè)注解的妙用的,但是當(dāng)我看到參數(shù)解析的時(shí)候 有這個(gè)一個(gè)注解,所以我了解了一下,當(dāng)我們返回像Map<String, Map<String, Object>>這種類型的時(shí)候,我們往往很難做到,因?yàn)檫@里面可能是多個(gè)表的數(shù)據(jù),所以我們不可能再建一個(gè)模型。
這時(shí)候我們就可以使用這個(gè)注解了
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface MapKey {
String value();
}
很明顯,這個(gè)注解是作用在方法上面的,具體的用法就是設(shè)置外面Map的KEY是什么。這樣我們就能夠查詢出非常復(fù)雜的結(jié)果,而不用在建立一個(gè)新的實(shí)體.
PS:下面看下MyBatis使用@MapKey注解接收多個(gè)查詢記錄到Map中,以便方便地用get()方法獲取字段的值
需求場景:
批量從數(shù)據(jù)庫查出若干條數(shù)據(jù),包括id和name兩個(gè)字段。希望可以把結(jié)果直接用Map接收,然后通過map.get(id)方便地獲取name的值。
問題:
如果使用下面的代碼,則如果查詢結(jié)果是多條就會報(bào)錯,因?yàn)镸yBatis是把結(jié)果以("id":123)、("name":"Jack")的形式保存在Map中的。所以如果返回結(jié)果一條包括了id和name的記錄就沒問題;如果返回多條記錄,即有多個(gè)("id":123)、("id":124),則MyBatis就傻掉不知如何處理了。
Map<String, Object> m = abcDao.getNamesByIds(idList);
解決的方法是在外面再用一個(gè)Map:
Map<Integer, Map<String, Object>> m = abcDao.getNamesByIds(idList);
然后,在這個(gè)dao的方法上面加一個(gè)注解:
<span style="white-space:pre"> </span>/**
<span style="white-space:pre"> </span> * 根據(jù)多個(gè)id批量獲取名稱
<span style="white-space:pre"> </span> * @param list 包含有Map key="id"的list
<span style="white-space:pre"> </span> * @return
<span style="white-space:pre"> </span> */
<span style="white-space:pre"> </span>@MapKey("id")
<span style="white-space:pre"> </span>public Map<Integer, Map<String, Object>> getNamesByIds(List<Map<String, Object>> list);
這個(gè)注解表示最外層Map的key為查詢結(jié)果中字段名為“id”的值。
Mapper.xml中的配置如下:
<select id="getNamesByIds" resultType="java.util.Map">
SELECT id, name FROM tb_abc WHERE id IN
<foreach item="item" collection="list" open="(" separator="," close=")">
#{item.id}
</foreach>
</select>
以上所述是小編給大家介紹的Mybatis中注解@MapKey的使用詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Spring Data MongoDB 數(shù)據(jù)庫批量操作的方法
在項(xiàng)目開發(fā)中經(jīng)常會批量插入數(shù)據(jù)和更新數(shù)據(jù)的操作,這篇文章主要介紹了Spring Data MongoDB 數(shù)據(jù)庫批量操作的方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-11-11
Java程序中實(shí)現(xiàn)調(diào)用Python腳本的方法詳解
這篇文章主要介紹了Java程序中實(shí)現(xiàn)調(diào)用Python腳本的方法,結(jié)合實(shí)例形式分析了eclipse環(huán)境中使用Java調(diào)用Python腳本的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-03-03
踩坑批量更新sql報(bào)錯,實(shí)際sql能夠正常執(zhí)行的問題
在項(xiàng)目工程遷移過程中,遇到了一個(gè)批量更新接口在新工程中報(bào)錯的問題,通過分析,排除了代碼錯誤的可能,最終發(fā)現(xiàn)是由于數(shù)據(jù)庫連接配置不當(dāng)導(dǎo)致的,在jdbc連接字符串中加入allowMultiQueries=true參數(shù)后,問題得以解決,這個(gè)參數(shù)的作用是允許SQL批量執(zhí)行2022-12-12
使用jquery 的ajax 與 Java servlet的交互代碼實(shí)例
這篇文章主要介紹了使用jquery 的ajax 與 Java servlet的交互代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09

