mybatis 如何判斷l(xiāng)ist集合是否包含指定數(shù)據(jù)
1、在mybatis腳本中想要判斷l(xiāng)ist中是否含有某個(gè)字符串。
2、動(dòng)態(tài)使用list中的屬性,添加到數(shù)據(jù)庫(kù)crud字段。
網(wǎng)上也沒搜到類似的案例,配置choose功能,可以方便做寫動(dòng)態(tài)sql拼裝,所以記錄下。
準(zhǔn)備之前腳本中用的最多的list函數(shù)就是size和遍歷了。那么mybatis腳本中是不是又包含函數(shù)了。首先我們要清楚list的類型。寫個(gè)簡(jiǎn)單的測(cè)試用例。
<select parameterType='java.util.Map' resultType='java.util.Map'>select <if test='list.containsKey(’0’)'> ’yes’ as a, </if> 1 </select>
在list后接一個(gè)方法containsKey,運(yùn)行后會(huì)拋出一個(gè)異常:
Caused by: org.apache.ibatis.ognl.MethodFailedException: Method 'containsKey' failed for object [0, 1] [java.lang.NoSuchMethodException: java.util.Arrays$ArrayList.containsKey(java.lang.Character)]
我們可以看到list的類型為:ArrayList,它沒有containsKey方法,但是我們知道List應(yīng)該有contains()方法,是的沒錯(cuò)。不過腳本在計(jì)算大小時(shí)size是不用加()的,加上還會(huì)拋異常。
細(xì)節(jié)上面異常中還有一個(gè)細(xì)節(jié)就是containsKey(java.lang.Character),Character在java里面是字符類型的,也就是List中如果是存的[0,1]或則[“0”,“1”],那么多少匹配不到了,比較整數(shù)只能是contains(0),比較字符串只能是雙引號(hào),而不能是單引號(hào),因?yàn)閖ava做了強(qiáng)制類型比較,而mybatis中雙引號(hào)需要用轉(zhuǎn)義字符",所以比較字符串必須有這種方式:
<if test='list.contains("0")'> #{邏輯}</if>從list動(dòng)態(tài)取數(shù)
-- 插入字段直接從list中獲取,通過${list[0].retainDay} 方式。
當(dāng)然也可以將list封裝到map里面,這樣代碼中就要多操作一步
<insert id='insert'> insert ignore into ads_circle_user_retain (eventDate,${list[0].retainDay}) VALUES <foreach collection='list' item='item' separator=','>(#{item.eventDate1},#{item.readNum}) </foreach> on DUPLICATE KEY UPDATE ${list[0].retainDay} = values(${list[0].retainDay}) </insert>集合(list)判斷是否存在對(duì)應(yīng)的字符串或?qū)ο?p>判斷集合中是否存在某個(gè)字符串對(duì)象,存在返回true,不存在返回false
list.contains('str1')
判斷集合中時(shí)候存在完全一樣的某個(gè)對(duì)象(所有屬性都一樣),存在返回true,不存在返回false
list.containsAll(Objcet obj)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. MySql導(dǎo)出后再導(dǎo)入數(shù)據(jù)時(shí)出錯(cuò)問題2. SQL Server靜態(tài)頁面導(dǎo)出技術(shù)13. Access中批量替換數(shù)據(jù)庫(kù)內(nèi)容的兩種方法4. MYSQL技巧:為現(xiàn)有字段添加自增屬性5. MySQL 字符串函數(shù):字符串截取6. MySQL分區(qū)的優(yōu)點(diǎn)7. Mysql入門系列:MYSQL創(chuàng)建、刪除、索引和更改表8. mysql 視圖操作和存儲(chǔ)過程9. Oracle的PDB數(shù)據(jù)庫(kù)創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問題及解決方法10. MySQL實(shí)現(xiàn)數(shù)據(jù)批量更新功能詳解
