一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Mybatis中注解@MapKey的使用詳解

Mybatis中注解@MapKey的使用詳解

2020-06-27 13:14mrr JAVA教程

mybatis的原身是ibatis,現在已經脫離了apache基金會。這篇文章主要介紹了Mybatis中注解@MapKey的使用的相關資料,需要的朋友可以參考下

mybatis的原身是ibatis,現在已經脫離了apache基金會,新官網是http://www.mybatis.org/

在研究Mybatis源碼之前并不知道這個注解的妙用的,但是當我看到參數解析的時候 有這個一個注解,所以我了解了一下,當我們返回像Map<String, Map<String, Object>>這種類型的時候,我們往往很難做到,因為這里面可能是多個表的數據,所以我們不可能再建一個模型。

這時候我們就可以使用這個注解了

?
1
2
3
4
5
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface MapKey {
String value();
}

很明顯,這個注解是作用在方法上面的,具體的用法就是設置外面Map的KEY是什么。這樣我們就能夠查詢出非常復雜的結果,而不用在建立一個新的實體.

PS:下面看下MyBatis使用@MapKey注解接收多個查詢記錄到Map中,以便方便地用get()方法獲取字段的值

需求場景:

批量從數據庫查出若干條數據,包括id和name兩個字段。希望可以把結果直接用Map接收,然后通過map.get(id)方便地獲取name的值。

問題:

如果使用下面的代碼,則如果查詢結果是多條就會報錯,因為MyBatis是把結果以("id":123)、("name":"Jack")的形式保存在Map中的。所以如果返回結果一條包括了id和name的記錄就沒問題;如果返回多條記錄,即有多個("id":123)、("id":124),則MyBatis就傻掉不知如何處理了。

?
1
Map<String, Object> m = abcDao.getNamesByIds(idList);

解決的方法是在外面再用一個Map:

?
1
Map<Integer, Map<String, Object>> m = abcDao.getNamesByIds(idList);

然后,在這個dao的方法上面加一個注解:

?
1
2
3
4
5
6
7
<span style="white-space:pre"> </span>/**
<span style="white-space:pre"> </span> * 根據多個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);

這個注解表示最外層Map的key為查詢結果中字段名為“id”的值。

Mapper.xml中的配置如下:

?
1
2
3
4
5
6
<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的使用詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产caonila在线观看 | 欧美日韩1区2区 | 四虎影院新网址 | 日本色午夜 | 国产精品亚洲va在线观看 | 99国产国人青青视频在线观看 | 动漫在线观看h | 久99视频精品免费观看福利 | 无毒成人社区 | 国产亚洲欧美日韩俺去了 | 1769国产精品免费视频 | bdsm中国精品调教 | 日本高清在线看 | 国产精品国语自产拍在线观看 | 啊啊啊好大视频 | 青青草原伊人网 | 精品综合久久久久久97超人 | 日本一卡2卡3卡4卡乱 | 日本一本二本三区免费 | 大肚孕妇的高h辣文 | 白发在线视频播放观看免费 | 被高跟鞋调教丨vk | 我的妹妹最近有点怪免费播放 | 三级伦理在线播放 | 日本三级在线观看免费 | 小SAO货叫大声点妓女 | 亚洲天堂岛国片 | 2020国产精品视频 | 免费高清视频免费观看 | 欧美高清免费一级在线 | 欧美精品久久一区二区三区 | 国产高清精品自在久久 | 九九精品99久久久香蕉 | 96av视频在线观看 | 99热在线观看免费 | 日本美女视频韩国视频网站免费 | 日本孕妇大胆孕交 | chinese壮直男gay老年人 | 日本成人黄色片 | 亚洲网红精品大秀在线观看 | 欧美一级一级做性视频 |