mybatis 如何判斷l(xiāng)ist集合是否包含指定數(shù)據(jù)
需求
1、在mybatis腳本中想要判斷l(xiāng)ist中是否含有某個字符串。
2、動態(tài)使用list中的屬性,添加到數(shù)據(jù)庫crud字段。
網(wǎng)上也沒搜到類似的案例,配置choose功能,可以方便做寫動態(tài)sql拼裝,所以記錄下。
準(zhǔn)備
之前腳本中用的最多的list函數(shù)就是size和遍歷了。那么mybatis腳本中是不是又包含函數(shù)了。首先我們要清楚list的類型。寫個簡單的測試用例。
<select id="test" parameterType="java.util.Map" resultType="java.util.Map"> select <if test="list.containsKey('0')"> 'yes' as a, </if> 1 </select>
在list后接一個方法containsKey,運(yùn)行后會拋出一個異常:
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()方法,是的沒錯。不過腳本在計(jì)算大小時size是不用加()的,加上還會拋異常。
細(xì)節(jié)
上面異常中還有一個細(xì)節(jié)就是containsKey(java.lang.Character),Character在java里面是字符類型的,也就是List中如果是存的[0,1]或則[“0”,“1”],那么多少匹配不到了,比較整數(shù)只能是contains(0),比較字符串只能是雙引號,而不能是單引號,因?yàn)閖ava做了強(qiáng)制類型比較,而mybatis中雙引號需要用轉(zhuǎn)義字符",所以比較字符串必須有這種方式:
<if test="list.contains("0")"> #{邏輯} </if>
從list動態(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)判斷是否存在對應(yīng)的字符串或?qū)ο?/h2>
判斷集合中是否存在某個字符串對象,存在返回true,不存在返回false
list.contains("str1")
判斷集合中時候存在完全一樣的某個對象(所有屬性都一樣),存在返回true,不存在返回false
list.containsAll(Objcet obj)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring的RedisTemplate存儲的key和value有特殊字符的處理
這篇文章主要介紹了Spring的RedisTemplate存儲的key和value有特殊字符的處理方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12學(xué)java得這樣學(xué),學(xué)習(xí)確實(shí)也得這樣
學(xué)java得這樣學(xué),學(xué)習(xí)東西確實(shí)也得這樣2008-02-02Java實(shí)現(xiàn)給網(wǎng)站上傳圖片蓋章的方法
這篇文章主要介紹了Java實(shí)現(xiàn)給網(wǎng)站上傳圖片蓋章的方法,涉及java針對圖片的合成操作技巧,類似水印功能,需要的朋友可以參考下2015-07-07SpringBoot實(shí)現(xiàn)文件的上傳、下載和預(yù)覽功能
在Spring Boot項(xiàng)目中實(shí)現(xiàn)文件的上傳、下載和預(yù)覽功能,可以通過使用Spring MVC的MultipartFile接口來處理文件上傳,并使用HttpServletResponse或Resource來實(shí)現(xiàn)文件下載和預(yù)覽,下面是如何實(shí)現(xiàn)這些功能的完整示例,需要的朋友可以參考下2024-08-08以Java代碼的方式總結(jié)幾個典型的內(nèi)存溢出案例
作為程序員,多多少少都會遇到一些內(nèi)存溢出的場景,如果你還沒遇到,說明你工作的年限可能比較短,或者你根本就是個假程序員!哈哈,開個玩笑.今天分享給大家Java內(nèi)存溢出的相關(guān)案例,希望大家在日常工作中,盡量避免寫這些low水平的代碼,需要的朋友可以參考下2021-06-06java 方法泛型入?yún)和String的重載關(guān)系詳解
這篇文章主要介紹了java 方法泛型入?yún)和String的重載關(guān)系詳解,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02java設(shè)計(jì)模式之適配器模式(Adapter)
這篇文章主要介紹了java設(shè)計(jì)模式之適配器模式Adapter的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01