您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Mybatis的mapper.xml中if標簽test判斷怎么使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Mybatis的mapper.xml中if標簽test判斷怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
① 將雙引號和單引號的位置互換
<if test=' testString != null and testString == "A" '> AND 表字段 = #{testString} </if>
② 加上.toString()
<if test=" testString != null and testString == 'A'.toString() "> AND 表字段 = #{testString} </if>
長久以來,我們判斷非空非null的判斷條件都是如下所示:
<if test="xxx !=null and xxx !=''">
但是這樣的判斷只是針對String的,如果是別的類型,這個條件就不一定成立了,比如最經典的:當是數字0時,這個判斷就會把0過濾掉,所以如果要判斷數字,我們一般會再加上一個0的判斷(這和mybatis的源碼邏輯有關,有興趣的可以去看看源碼)
<if test="xxx !=null and xxx !='' or xxx == 0">
但是如果傳進來的是數組或者集合呢?我們要再寫別的判斷嗎?能不能封裝個方法呢?
答案是可以的。
if標簽里面的test判斷是可以使用工具類來做判斷的,畢竟test后面跟的也是一個布爾值,其用法是:
<if test="@完整的包名類名@方法名(傳參)">
例如:
<if test="@com.xxx.util.MybatisTestUtil@isNotEmpty(obj)">
下面是我寫的一個簡陋的工具類,不是很全面,拋磚引玉,各位可以根據需要補充。
import java.util.Collection; import java.util.Map; /** * @description: mybatis的<if test="">標簽中使用的非空判斷工具類 * 使用方式:<if test="@com.xxx.xxx.util.MybatisTsetUtil@isNotEmpty(obj)"> * @author: singleDog * @date: 2020/7/20 */ public class MybatisTestUtil { public static boolean isEmpty(Object o) { if (o == null) { return true; } if (o instanceof String) { return ((String) o).trim().length() == 0; } else if (o instanceof Collection) { return ((Collection) o).isEmpty(); } else if (o instanceof Map) { return ((Map) o).isEmpty(); } else if (o.getClass().isArray()) { return ((Object[]) o).length == 0; } else { return false; } } public static boolean isNotEmpty(Object o) { return !isEmpty(o); } }
<if test="list.contains(xxx)"> //... </if>
注意,元素類型是字符串的話,參考1中的寫法,一般這樣寫
<!--包含--> <if test="list.contains('示例元素'.toString())"> //... </if> <!--不包含--> <if test="!list.contains('示例元素'.toString())"> //... </if>
map中添加了兩個int類型的數據,
map.put("startNum",(page.getPageNum()-1)*page.getNumPerPage()); map.put("pageSize",page.getNumPerPage());
錯誤的SQL書寫:
<if test="startNum != null and startNum != '' "> LIMIT #{startNum},#{pageSize} </if>
正確的SQL書寫
<if test="startNum != null"> LIMIT #{startNum},#{pageSize} </if>
因為startNum里存的是int數據,所以不能與空字符串進行比較,強行比較時會報錯。
map中添加的是一個字符串形式的“1”
map.put("uploadFlag",upload.getUploadFlag());
如果想在XML中比較,以下兩種方式都可以:
2.1 test使用雙引號
比較的對象使用單引號點toString()方法:
<if test="uploadFlag=='1'.toString()"> and pw.id in (select pw_id from t_contract_upload) </if>
2.2 test使用單引號
比較的對象直接使用雙引號:
<if test='uploadFlag=="2" '> and pw.id in (select pw_id from t_contract_upload) </if>
讀到這里,這篇“Mybatis的mapper.xml中if標簽test判斷怎么使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。