mybatis中的test語句失效處理方式
mybatis test語句失效
正常情況下,寫動態(tài)sql的if test或when test語句時,條件引用為雙引號括單引號
如下:
?<select id="sel1" resultType="User">
? ? ? ? ? select * from tb_user
? ? ? ? ? <where>
? ? ? ? ? ? ? <choose>
? ? ? ? ? ? ? ? ? <when test="user != null and user != ''">
? ? ? ? ? ? ? ? ? ? ? and user = #{user}
? ? ? ? ? ? ? ? ? </when>
? ? ? ? ? ? ? ? ? <when test="passwd != null and passwd != ''">
? ? ? ? ? ? ? ? ? ? ? and passwd = #{passwd}
? ? ? ? ? ? ? ? ?</when>
? ? ? ? ? ? ? ? ?<otherwise>
? ? ? ? ? ? ? ? ? ? ?and 1 = 1
? ? ? ? ? ? ? ? ?</otherwise>
? ? ? ? ? ? ?</choose>
? ? ? ? ?</where>
?</select>?但是今天發(fā)現(xiàn)一個問題,當(dāng)傳入的值為0或者1時,sql失效不被執(zhí)行。
如下:
<when test="user == '1‘ ">
? and user = #{user}
</when>之后,發(fā)現(xiàn)是MyBatis自身解析的問題,在標(biāo)簽 中的內(nèi)容,MyBatis是使用的OGNL表達(dá)式來進(jìn)行解析的,這個地方需要注意下,單引號內(nèi)有一個字符的情況下,OGNL會將其以 java 中的 char 類型進(jìn)行解析,那么此時 char 類型與參數(shù) String 類型用等號進(jìn)行比較的時候結(jié)果都是false。
解決方案也很簡單
就是把test 中的單個字符用雙引號括起來。
<if test='param != "*"'>
? ? <choose> ?
? ? ? ? <when test='param.indexOf("sub") != -1'> ?
?? ??? ?
? ? ? ? </when> ?
? ? ? ? <otherwise> ??
?? ? ? ? ? ?
? ? ? ? </otherwise> ?
? ? </choose>?
</if>mybatis test判斷注意事項
在使用mybatis進(jìn)行判斷的時候,一定要注意傳入的數(shù)據(jù)類型與判斷的目標(biāo)值類型是否一致。
最近在一次開發(fā)過程
誤將一個傳入的整型數(shù)據(jù)使用了下面的判斷方式
<if test="appType != null and appType != ''">
and a.c_appType = #{appType}
</if>其中,appType是一個整型數(shù)據(jù)??梢钥吹剑趖est判斷里面使用了 appType != ''。
在進(jìn)行業(yè)務(wù)功能測試的時候發(fā)現(xiàn),當(dāng)傳入的值是0時,該條件篩選沒有起作用,通過調(diào)試發(fā)現(xiàn),mybatis會將空字符串轉(zhuǎn)換成double類型的0.0
如下圖所示:

同樣整數(shù)數(shù)據(jù)也會轉(zhuǎn)換為double類型
如下圖所示:

所以,mybatis在判斷的時候,數(shù)字0和空字符串是相等的,而我們的if判斷里,是兩者不相等時該條件才會起作用。
因此,在使用mybatis判斷的時候,一定要注意類型是否一致,數(shù)字類型就不要判斷空字符串的情況了。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于SpringCloud的微服務(wù)以及組件詳解
這篇文章主要介紹了關(guān)于SpringCloud的微服務(wù)以及組件詳解,是一個更高層次的、 架構(gòu)視角的綜合性大型項目, 他的目標(biāo)是構(gòu)建一套標(biāo)準(zhǔn)化的微服務(wù)解決方案,需要的朋友可以參考下2023-05-05
Java中使用內(nèi)存映射實現(xiàn)大文件上傳實例
這篇文章主要介紹了Java中使用內(nèi)存映射實現(xiàn)大文件上傳實例,本文對比測試了FileInputStream 或者FileOutputStream 抑或RandomAccessFile的頻繁讀寫操作,最后總結(jié)出映射到內(nèi)存后進(jìn)行讀寫以提高速度,需要的朋友可以參考下2015-01-01
MybatisPlus BaseMapper 中的方法全部 Invalid bound statement (not f
這篇文章主要介紹了MybatisPlus BaseMapper 中的方法全部 Invalid bound statement (not found)的Error處理方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
Spring中使用自定義ThreadLocal存儲導(dǎo)致的坑及解決
這篇文章主要介紹了Spring中使用自定義ThreadLocal存儲導(dǎo)致的坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
Springboot集成knife4j實現(xiàn)風(fēng)格化API文檔
這篇文章主要介紹了Springboot如何集成knife4j實現(xiàn)風(fēng)格化API文檔,幫助大家更好的使用springboot框架,感興趣的朋友可以了解下2020-12-12
springboot配置請求超時時間(Http會話和接口訪問)
本文主要介紹了springboot配置請求超時時間,包含Http會話和接口訪問兩種,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07

