mybatis的if判斷不要使用boolean值的說(shuō)明
mybatis的if判斷里面最好不要使用boolean值:
mybatis會(huì)默認(rèn)把空值轉(zhuǎn)為false。所以如果遇見(jiàn)前段傳空值,這個(gè)字段在mybatis里面永遠(yuǎn)就是false了,
可以使用數(shù)字類型代替,但是不要使用0作為參數(shù);
補(bǔ)充知識(shí):【MyBatis】<if test=''></if>標(biāo)簽的條件判斷(Boolean類型參數(shù))
在MyBatis 中,動(dòng)態(tài) SQL 元素和 JSTL 或基于類似 XML 的文本處理器相似。
在 MyBatis 3 之前的版本中,有很多元素需要花時(shí)間了解。而MyBatis 3 大大精簡(jiǎn)了元素種類,只需學(xué)習(xí)原來(lái)一半的元素便可。
MyBatis 采用功能強(qiáng)大的基于 OGNL 的表達(dá)式來(lái)淘汰其它大部分元素。
<!-- <if test=' '></if>標(biāo)簽的使用實(shí)例--> <select resultType='Blog'> SELECT * FROM BLOG WHERE state = ‘ACTIVE’ <if test='title != null'> AND title like #{title,jdbcType=VARCHAR} </if></select>
<!-- <if test=''></if>標(biāo)簽 --> <!-- 對(duì)于字符串類型參數(shù),可以用如下寫(xiě)法: --><if test='username' != null> username=#{username, jdbcType=VARCHAR}</if> <!-- 或者 --><if test='username != null and ’John’ == username'> username=#{username, jdbcType=VARCHAR}</if> <!-- 但是,對(duì)于非字符串類型的參數(shù)(如Boolean),就需要寫(xiě)成: --><if test='flag != null and ’true’.toString() == flag.toString()'> flage=#{flag, jdbcType=BOOLEAN}</if>
以上這篇mybatis的if判斷不要使用boolean值的說(shuō)明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Sql Server 壓縮數(shù)據(jù)庫(kù)日志文件的方法2. MariaDB中1045權(quán)限錯(cuò)誤導(dǎo)致拒絕用戶訪問(wèn)的錯(cuò)誤解決方法3. MySQL 常用函數(shù)總結(jié)4. 實(shí)例講解MySQL 慢查詢5. Microsoft Office Access凍結(jié)字段的方法6. DB2數(shù)據(jù)庫(kù)控制中心亂碼問(wèn)題解決方法集合7. 詳解MySQL 慢查詢8. 簡(jiǎn)單聊一聊SQL中的union和union all9. Mysql數(shù)據(jù)庫(kù)慢查詢常用優(yōu)化方式10. SQL Server主鍵約束(PRIMARY KEY)

網(wǎng)公網(wǎng)安備