欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis中的test語句失效處理方式

 更新時間:2022年03月12日 09:55:25   作者:艾艾貓dori  
這篇文章主要介紹了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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

最新評論