首頁 > 軟體

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

2022-03-12 13:00:14

mybatis test語句失效

正常情況下,寫動態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> 

但是今天發現一個問題,當傳入的值為0或者1時,sql失效不被執行。

如下:

<when test="user == '1‘ ">
  and user = #{user}
</when>

之後,發現是MyBatis自身解析的問題,在標籤 中的內容,MyBatis是使用的OGNL表示式來進行解析的,這個地方需要注意下,單引號內有一個字元的情況下,OGNL會將其以 java 中的 char 型別進行解析,那麼此時 char 型別與引數 String 型別用等號進行比較的時候結果都是false。

解決方案也很簡單

就是把test 中的單個字元用雙引號括起來。

<if test='param != "*"'>
    <choose>  
        <when test='param.indexOf("sub") != -1'>  
        
        </when>  
        <otherwise>   
            
        </otherwise>  
    </choose> 
</if>

mybatis test判斷注意事項

在使用mybatis進行判斷的時候,一定要注意傳入的資料型別與判斷的目標值型別是否一致。

最近在一次開發過程

誤將一個傳入的整型資料使用了下面的判斷方式

<if test="appType != null and appType != ''">
    and a.c_appType = #{appType}
</if>

其中,appType是一個整型資料。可以看到,在test判斷裡面使用了 appType != ''。

在進行業務功能測試的時候發現,當傳入的值是0時,該條件篩選沒有起作用,通過偵錯發現,mybatis會將空字串轉換成double型別的0.0

如下圖所示:

同樣整數資料也會轉換為double型別

如下圖所示:

所以,mybatis在判斷的時候,數位0和空字串是相等的,而我們的if判斷裡,是兩者不相等時該條件才會起作用。

因此,在使用mybatis判斷的時候,一定要注意型別是否一致,數位型別就不要判斷空字串的情況了。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com