av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

淺談Mybatis中resultType為hashmap的情況

瀏覽:68日期:2023-10-21 08:11:36

現在有一張user表

id ,name,age

我們進行一個簡單的查詢:

<select resultType='Uer'> select id ,name,age from user</select>

查詢完后,怎么去接收這個查詢結果呢,通常在這個mapper.xml對應的接口中使用List<User>做為返回值去接收,最后存儲的樣子就是下面的圖

淺談Mybatis中resultType為hashmap的情況

這是一個很簡單的單表查詢操作,其實這種簡單的單表查詢操作不需要引入User類,直接使用resultType='hashmap',接口中使用List<Object>做為返回值去接(hashmap也是對象的一種所以可以直接使用Obeject),讓查詢結果自動封裝成Map對象存入list中也可以返回

<select resultType='hashmap'> select id ,name,age from user</select>

當使用hashmap作為返回值類型時,Mybatis會自動將字段名作為key值,將對應的字段值作為value封裝到map中,一條記錄有多個字段,產生多個key-value鍵值對存到一個map對象中,多條記錄就會生成多個map對象,多個map對象存到list中返回

淺談Mybatis中resultType為hashmap的情況

注意:如果字段對應的值為空,那么在封裝map的時候,這個字段會直接被忽略調。

補充知識:resultType='java.util.HashMap' sql返回的null值,不在map里面

問:

mapper配置如下

<select resultType='java.util.HashMap'> select id,name,nickname,status from user order by create_time desc</select>

name, nickname 有的是null

這樣導致,查詢出來的map,本來map.size=4的

但是,如果查詢出來的name為null,那么返回的hashmap里面就沒有name了

同樣,nickname也是一樣,請問,如何解決這個問題

我不想在sql里面用nvl函數去做

答:

<settings> <setting name='callSettersOnNulls' value='true'/></settings>

把這個加到你的mybatis-config.xml里。

以上這篇淺談Mybatis中resultType為hashmap的情況就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 午夜黄视频 | 婷婷在线播放 | 四虎影库 | 国产永久在线 | 欧美区在线 | 午夜网址 | 日韩欧美中文字幕在线观看 | 国产高潮在线 | 日本一级淫片色费放 | 免费一级毛片免费播放 | 欧美日韩亚洲一区 | 高潮毛片又色又爽免费 | 亚洲欧美精品一区 | 美女无遮挡网站 | 99午夜 | 欧美不卡| 日韩毛片 | 91青青草| 久久免费视频观看 | 精品视频一区二区三区四区 | 香蕉一区二区 | 69av在线播放 | 国产一区视频在线播放 | 欧美一区二区三区成人 | 99久久婷婷国产综合精品草原 | 黑人巨大猛烈捣出白浆 | 精品国产欧美 | 韩日一级片 | 99视频在线精品免费观看2 | 亚洲第一黄网 | 久久视频一区二区 | 国产欧美精品一区二区三区 | 久久免费小视频 | 国产成人区| 午夜影院在线观看 | 亚洲欧美专区 | 在线一区二区三区 | 午夜爱| 在线看片你懂的 | 全部免费毛片在线播放高潮 | 一级理论片 |