欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談MyBatis循環(huán)Map(高級用法)

 更新時間:2020年09月22日 14:45:49   作者:胖先森  
這篇文章主要介紹了淺談MyBatis循環(huán)Map(高級用法),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

今天遇到一個比較特殊的業(yè)務(wù),需要對傳入的Map數(shù)據(jù)在映射文件中進(jìn)行遍歷,在之前的學(xué)習(xí)中,我們也知道MyBatis有默認(rèn)對集合的操作list和array,但是沒有默認(rèn)的map,所有不能直接寫collection="map",如果這么處理,它會當(dāng)成是根據(jù)map.get("map")獲取傳遞value只,==大部分情況下是一個map中是不會有“map”這個key的,于是就是報錯==。如果你想用map標(biāo)識來獲取參數(shù)map,就需要保證傳入的Map參數(shù)有@Param("map")注解。

1.Mybatis入?yún)ap的使用

1.1 傳遞Map數(shù)據(jù)

第一種:自己封裝傳遞Map中的KEY值,模擬數(shù)據(jù)

//service:
public List<UserDepte> getByMap(Map<String,List<Long>> map){
    Map<String,Object> paramsMap= new HashMap<String, Object>();
    params.put("paramsMap", map);
    return this.getByMap(paramsMap);  
}
//dao:
int getByMap(Map<String,Object> map)

第二種:個人推薦@Param注解

//service直接調(diào)用dao
int getByMap(@param("paramsMap") Map<String,Object> map)

1.2 映射文件XML

(1)循環(huán)KEY值寫法:

<foreach collection="paramsMap.keys" item="k" separator="and">  
  ${k} = #{k}  
</foreach> 

(2)循環(huán)VAVLUE值寫法

<foreach collection="paramsMap.values" item="v" separator="and">  
  ${v} = #{v}  
</foreach> 

其實本質(zhì)就是使用的Map.Entiy對象中的屬性,自己回顧一下Java中對Map的遍歷方式有幾種

1.3 KEY獲取VALUE

<foreach collection="paramsMap.keys" item="k" separator="and">  
  <if test="null != paramsMap[k]">  
    ${k} = ${paramsMap[k]}  
  </if> 
</foreach> 

==注意:這里使用的$來獲取數(shù)據(jù),絕大部分情況下我們個人不推薦使用$符號==

個人推薦方式:一次循環(huán)得到key和value值,這里使用#和$都是可以的

<foreach collection="paramsMap" index="key" item="value">
  #{key} = #{value}
</foreach>

==回顧:#和$的區(qū)別,應(yīng)該還記得吧!==

1.4 表達(dá)式書寫錯誤

通常我們設(shè)置值的時候,會以#{}的方式,而不是${},如下:==錯誤寫法==

<foreach collection="paramsMap.keys" item="k" separator=",">  
  <if test="null != paramsMap[k]">  
    ${k} = #{paramsMap[k]}  
  </if> 
</foreach> 

這樣書寫,取不了值了,${condition[k]} 能取的出值,但#{condition[k]} 取出來的值卻實null,正確的寫法應(yīng)該是:

<foreach collection="paramsMap.keys" item="k" separator=",">  
  <if test="null != paramsMap[k]">  
    ${k} = #{paramsMap[${k}]} <!-- 請注意這種寫法,我個人還是喜歡一次性獲取key和value的寫法 -->
  </if> 
</foreach> 

2.Map高級用法

MyBatis嵌套循環(huán)map的高級用法:假如參數(shù)類型是這么一個類型結(jié)構(gòu): Map map = new HashMap<String,List<String>>,我想要拼裝出來的sql如下:

select * from 表名
where (
  (id = 1 and name in ('悟空','唐僧','八戒') or
  (id = 2 and name in ('劉備','張飛','關(guān)羽') or
  (id = 3 and name in ('小三','王五','王八') or
  ……
)

id對應(yīng)的是Map中KEY,而in中的數(shù)據(jù)是Map中的value

Map<String,List<String>> map = new HashMap<>();
List<String> nameList = new ArrayList<>();
nameList.add("悟空");
nameList.add("唐僧");
nameList.add("八戒");
map.put("1",nameList);

nameList = new ArrayList<>();
nameList.add("劉備");
nameList.add("張飛");
nameList.add("關(guān)羽");
map.put("2",nameList);

(1)第一種寫法:就是通過KEY獲取value的形式

SELECT * FROM 表名
WHERE 
<foreach collection="paramsMap.keys" item="key" open="(" separator="OR" close=")">
  (id = #{key} AND name in
  <foreach collection = "paramsMap[key]" item="name" separator="," open="(" close=")">
    #{name}
  </foreach>
  )
</foreach>

(1)第二種寫法:個人喜歡的方式

SELECT * FROM 表名
WHERE 
<foreach collection="paramsMap" index="key" item="value" open="(" separator="OR" close=")">
  (id = #{key} AND name in
  <foreach collection = "value" item="name" separator="," open="(" close=")">
    #{name}
  </foreach>
  )
</foreach>

 到此這篇關(guān)于淺談MyBatis循環(huán)Map(高級用法)的文章就介紹到這了,更多相關(guān)MyBatis循環(huán)Map內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java讀取xml文件的五種方式

    Java讀取xml文件的五種方式

    在編寫與 XML 數(shù)據(jù)交互的現(xiàn)代軟件應(yīng)用時,有效地讀取和解析 XML 文件是至關(guān)重要的,本文旨在探討 Java 中處理 XML 文件的五種主要方法:DOM、SAX、StAX、JAXB 和 JDOM,我們將詳細(xì)介紹每種方法的工作原理、典型用途以及如何在 Java 程序中實現(xiàn)它們
    2024-05-05
  • java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù)

    java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù)

    今天小編就為大家分享一篇java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • 深入探究Spring底層核心原理

    深入探究Spring底層核心原理

    理解IOC與AOP的實現(xiàn)機(jī)制,優(yōu)化應(yīng)用性能與可維護(hù)性。Spring通過IOC容器管理Bean,AOP實現(xiàn)切面編程,支持事務(wù)管理、ORM框架等。深入理解Spring原理,可以幫助我們更好地使用Spring框架,提高開發(fā)效率與質(zhì)量
    2023-04-04
  • 關(guān)于Swagger注釋API的使用說明

    關(guān)于Swagger注釋API的使用說明

    這篇文章主要介紹了關(guān)于Swagger注釋API的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • jmeter中beanshell的用法小結(jié)

    jmeter中beanshell的用法小結(jié)

    本文主要介紹了jmeter中beanshell的用法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Java分支結(jié)構(gòu)程序設(shè)計實例詳解

    Java分支結(jié)構(gòu)程序設(shè)計實例詳解

    這篇文章主要介紹了Java分支結(jié)構(gòu)程序設(shè)計例題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • mybatis 在typeAliases別名時報錯的解決

    mybatis 在typeAliases別名時報錯的解決

    這篇文章主要介紹了mybatis 在typeAliases別名時報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • MyBatis-Plus實現(xiàn)多表聯(lián)查的方法實戰(zhàn)

    MyBatis-Plus實現(xiàn)多表聯(lián)查的方法實戰(zhàn)

    這篇文章主要給大家介紹了關(guān)于MyBatis-Plus實現(xiàn)多表聯(lián)查的方法,MyBatis Plus是一款針對MyBatis框架的增強工具,它提供了很多方便的方法來實現(xiàn)多表聯(lián)查,需要的朋友可以參考下
    2023-07-07
  • springboot結(jié)合全局異常處理實現(xiàn)登錄注冊驗證

    springboot結(jié)合全局異常處理實現(xiàn)登錄注冊驗證

    這篇文章主要介紹了springboot結(jié)合全局異常處理實現(xiàn)登錄注冊驗證,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • SpringMVC @RequestMapping注解作用詳解

    SpringMVC @RequestMapping注解作用詳解

    通過@RequestMapping注解可以定義不同的處理器映射規(guī)則,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@RequestMapping注解用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01

最新評論