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)一個問題,當傳入的值為0或者1時,sql失效不被執(zhí)行。
如下:
<when test="user == '1‘ "> ? and user = #{user} </when>
之后,發(fā)現(xiàn)是MyBatis自身解析的問題,在標簽 中的內容,MyBatis是使用的OGNL表達式來進行解析的,這個地方需要注意下,單引號內有一個字符的情況下,OGNL會將其以 java 中的 char 類型進行解析,那么此時 char 類型與參數(shù) String 類型用等號進行比較的時候結果都是false。
解決方案也很簡單
就是把test 中的單個字符用雙引號括起來。
<if test='param != "*"'> ? ? <choose> ? ? ? ? ? <when test='param.indexOf("sub") != -1'> ? ?? ??? ? ? ? ? ? </when> ? ? ? ? ? <otherwise> ?? ?? ? ? ? ? ? ? ? ? ? </otherwise> ? ? ? </choose>? </if>
mybatis test判斷注意事項
在使用mybatis進行判斷的時候,一定要注意傳入的數(shù)據(jù)類型與判斷的目標值類型是否一致。
最近在一次開發(fā)過程
誤將一個傳入的整型數(shù)據(jù)使用了下面的判斷方式
<if test="appType != null and appType != ''"> and a.c_appType = #{appType} </if>
其中,appType是一個整型數(shù)據(jù)。可以看到,在test判斷里面使用了 appType != ''。
在進行業(yè)務功能測試的時候發(fā)現(xiàn),當傳入的值是0時,該條件篩選沒有起作用,通過調試發(fā)現(xiàn),mybatis會將空字符串轉換成double類型的0.0
如下圖所示:
同樣整數(shù)數(shù)據(jù)也會轉換為double類型
如下圖所示:
所以,mybatis在判斷的時候,數(shù)字0和空字符串是相等的,而我們的if判斷里,是兩者不相等時該條件才會起作用。
因此,在使用mybatis判斷的時候,一定要注意類型是否一致,數(shù)字類型就不要判斷空字符串的情況了。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
nacos注冊中心單節(jié)點ap架構源碼解析(最新推薦)
這篇文章主要介紹了nacos注冊中心單節(jié)點ap架構源碼解析,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01SpringBoot+Vue實現(xiàn)EasyPOI導入導出的方法詳解
項目開發(fā)過程中,很大的需求都有 導入導出功能。本文將利用SpringBoot+Vue實現(xiàn)EasyPOI導入導出功能,感興趣的可以了解一下2022-08-08Java應用啟動停止重啟Shell腳本模板server.sh
這篇文章主要為大家介紹了Java應用啟動、停止、重啟Shell腳本模板server.sh,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08Java獲取兩個集合List的交集、補集、并集(相加)和差集(相減)的不同方式
這篇文章主要給大家介紹了關于Java獲取兩個集合List的交集、補集、并集(相加)和差集(相減)的不同方式,在一般操作中對于list集合取交集、差集、并集,比較簡單,需要的朋友可以參考下2023-08-08