您好,登錄后才能下訂單哦!
本篇內容主要講解“mybatis 怎么判斷list集合是否包含指定數據”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“mybatis 怎么判斷list集合是否包含指定數據”吧!
1、在mybatis腳本中想要判斷list中是否含有某個字符串。
2、動態使用list中的屬性,添加到數據庫crud字段。
網上也沒搜到類似的案例,配置choose功能,可以方便做寫動態sql拼裝,所以記錄下。
之前腳本中用的最多的list函數就是size和遍歷了。那么mybatis腳本中是不是又包含函數了。首先我們要清楚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,運行后會拋出一個異常:
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應該有contains()方法,是的沒錯。不過腳本在計算大小時size是不用加()的,加上還會拋異常。
上面異常中還有一個細節就是containsKey(java.lang.Character),Character在java里面是字符類型的,也就是List中如果是存的[0,1]或則[“0”,“1”],那么多少匹配不到了,比較整數只能是contains(0),比較字符串只能是雙引號,而不能是單引號,因為java做了強制類型比較,而mybatis中雙引號需要用轉義字符",所以比較字符串必須有這種方式:
<if test="list.contains("0")"> #{邏輯} </if>
-- 插入字段直接從list中獲取,通過${list[0].retainDay} 方式。
當然也可以將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>
判斷集合中是否存在某個字符串對象,存在返回true,不存在返回false
list.contains("str1")
判斷集合中時候存在完全一樣的某個對象(所有屬性都一樣),存在返回true,不存在返回false
list.containsAll(Objcet obj)
到此,相信大家對“mybatis 怎么判斷list集合是否包含指定數據”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。