mybatis嵌套循環(huán)map方式(高級用法)
mybatis嵌套循環(huán)map
mybatis有默認(rèn)的list,array,但是沒有默認(rèn)的map。所以不能直接寫collection="map",如果這么寫,它會當(dāng)成是根據(jù)map.get(“map”)來取value值,大部分情況下是一個map中是不會有“map”這個key的,于是就是報(bào)錯。
如果你想用這個“map”標(biāo)識取參數(shù)map,就需要保證傳入的Map參數(shù)有@Param("map")注解。
mybatis入?yún)ap的基本語法
service,dao的寫法:
//service:
public List<BpmDefUser> 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)或者(推薦):
//service直接調(diào)用dao
int getByMap(@param("paramsMap") Map<String,Object> map)xml的寫法:
循環(huán)key:
? ? <foreach collection="paramsMap.keys" item="k" separator="and"> ??
? ? ? ? ${k} = #{k} ? ?
? ? </foreach> ??循環(huán)values
<foreach collection="paramsMap.values" item="v" separator="and"> ??
? ? ${v} = #{v} ? ?
</foreach> ?循環(huán)獲取key和值:
<foreach collection="paramsMap.keys" item="k" separator="and"> ??
? ? <if test="null != paramsMap[k]"> ? ?
? ? ? ? ${k} = ${paramsMap[k]} ? ?
? ? </if> ?
</foreach> ??或者一次循環(huán)得到key和value值(推薦):
<foreach collection="paramsMap" index="key" ?item="value">
? ? ? ? ?${key} = ${value}
</foreach>易錯點(diǎn):表達(dá)式抒寫錯誤
通常我們設(shè)置值的時候,會以#{}的方式,而不是${},如下:
<foreach collection="paramsMap.keys" item="k" separator=","> ??
? ? <if test="null != paramsMap[k]"> ? ?
? ? ? ? ${k} = #{paramsMap[k]} ? ?
? ? </if> ?
</foreach> ??你會發(fā)現(xiàn),取不了值了,${condition[k]} 能取的出值,但#{condition[k]} 取出來的值卻實(shí)null,正確的寫法應(yīng)該是:
<foreach collection="paramsMap.keys" item="k" separator=","> ??
? ? <if test="null != paramsMap[k]"> ? ?
? ? ? ? ${k} = #{paramsMap[${k}]} ?
? ? </if> ?
</foreach> ??mybatis嵌套循環(huán)map的高級用法
假如參數(shù)類型是這么一個類型結(jié)構(gòu): Map map = new HashMap<String,HashSet<String>>,我想要拼裝出來的sql如下:
select * from 表名
where (
? ? (id = 1 and name in ('小二','小三','小四') or
? ? (id = 2 and name in ('小二','小三','趙六') or
? ? (id = 3 and name in ('小三','王五','王八') or
? ? ……
)mybatis應(yīng)該怎么寫?
第一種寫法:
?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>第二種寫法(推薦):
?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>mybatis中循環(huán)map集合操作
首先聲明一個MAP集合,用來存放數(shù)據(jù):如下圖:聲明map集合pd,將數(shù)據(jù)put到pd中,然后在聲明一個map集合params,將pd幾個放入params集合中,將params作為參數(shù),參入xml配置文件中:

在xml中:

傳入到xml文件中的集合params里,鍵值為relationMap對應(yīng)著另一個map幾個pd,所以在<foreach>標(biāo)簽中collection為relationMap,index為map的key,item為map的value;#{key},#{value}即可取到pd這個map集合中的鍵值。
至于${key},由于我寫的是個插入語句,key值作為字段,value作為值,#{key}取出來的為字符串,而oracle數(shù)據(jù)庫表明字段不能為字符串,用${key}取出即可;
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot如何根據(jù)docx填充生成word文件并導(dǎo)出pdf
這篇文章主要介紹了Springboot如何根據(jù)docx填充生成word文件并導(dǎo)出pdf問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Spring框架實(shí)現(xiàn)滑動驗(yàn)證碼功能的代碼示例
之前項(xiàng)目需要在驗(yàn)證碼模塊,增加滑動驗(yàn)證碼,用來給手機(jī)端使用的,大概看了下,主要方法就是將圖片切割,然后記住偏移量,進(jìn)行滑動,所以本文給大家介紹了Spring框架實(shí)現(xiàn)滑動驗(yàn)證碼功能的方法示例,需要的朋友可以參考下2024-07-07
基于SpringBoot和Vue3的博客平臺的用戶注冊與登錄功能實(shí)現(xiàn)
本教程將指導(dǎo)您如何使用Spring?Boot和Vue3實(shí)現(xiàn)用戶注冊與登錄功能。我們將使用Spring?Boot作為后端框架,Vue3作為前端框架,同時使用MySQL作為數(shù)據(jù)庫,感興趣的朋友可以參考一下2023-04-04
Java8新特性之JavaFX 8_動力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java8新特性之JavaFX 8的相關(guān)知識,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-06-06

