mybatis中 if-test 數(shù)字判斷的坑及解決
if-test數(shù)字判斷的坑
在項(xiàng)目中偶然發(fā)現(xiàn)一個(gè)判斷數(shù)字的if沒(méi)有起任何作用,代碼如下
<if test="timeType !=null and timeType!='' and timeType == '3'"> ? ? AND ? ? ... </if>
經(jīng)過(guò)查詢(xún)資料發(fā)現(xiàn),mybatis是用OGNL表達(dá)式來(lái)解析的,在OGNL的表達(dá)式中,數(shù)字’3’會(huì)被解析成字符,java是強(qiáng)類(lèi)型的,char 和 一個(gè)string 會(huì)導(dǎo)致不等,所以if標(biāo)簽中的sql不會(huì)被解析。
所以應(yīng)該改為:
?<if test="timeType !=null and timeType!='' and timeType == '3'.toString() "> ? ? ? ? ? ? AND ? ? ? ? ? ? ... ?</if>
然后發(fā)現(xiàn)確實(shí)解決了這個(gè)問(wèn)題,特此記錄。
mybatis的test判斷注意事項(xiàng)
在使用mybatis進(jìn)行判斷的時(shí)候,一定要注意傳入的數(shù)據(jù)類(lèi)型與判斷的目標(biāo)值類(lèi)型是否一致。
最近在一次開(kāi)發(fā)過(guò)程,誤將一個(gè)傳入的整型數(shù)據(jù)使用了下面的判斷方式:
<if test="appType != null and appType != ''"> and a.c_appType = #{appType} </if>
其中,appType是一個(gè)整型數(shù)據(jù)??梢钥吹?,在test判斷里面使用了 appType != ''。
在進(jìn)行業(yè)務(wù)功能測(cè)試的時(shí)候發(fā)現(xiàn),當(dāng)傳入的值是0時(shí),該條件篩選沒(méi)有起作用,通過(guò)調(diào)試發(fā)現(xiàn),mybatis會(huì)將空字符串轉(zhuǎn)換成double類(lèi)型的0.0,如下圖所示:
同樣的,整數(shù)數(shù)據(jù)也會(huì)轉(zhuǎn)換為double類(lèi)型,如下圖所示:
所以,mybatis在判斷的時(shí)候,數(shù)字0和空字符串是相等的,而我們的if判斷里,是兩者不相等時(shí)該條件才會(huì)起作用。
因此,在使用mybatis判斷的時(shí)候,一定要注意類(lèi)型是否一致,數(shù)字類(lèi)型就不要判斷空字符串的情況了。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot實(shí)現(xiàn)配置本地訪問(wèn)端口及路徑
這篇文章主要介紹了springboot實(shí)現(xiàn)配置本地訪問(wèn)端口及路徑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Spring Boot中使用Server-Sent Events (SSE) 實(shí)
Server-Sent Events (SSE) 是HTML5引入的一種輕量級(jí)的服務(wù)器向?yàn)g覽器客戶(hù)端單向推送實(shí)時(shí)數(shù)據(jù)的技術(shù),本文主要介紹了Spring Boot中使用Server-Sent Events (SSE) 實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)推送教程,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03RabbitMQ?延遲隊(duì)列實(shí)現(xiàn)訂單支付結(jié)果異步階梯性通知(實(shí)例代碼)
這篇文章主要介紹了RabbitMQ?延遲隊(duì)列實(shí)現(xiàn)訂單支付結(jié)果異步階梯性通知,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02spring?boot對(duì)敏感信息進(jìn)行加解密的項(xiàng)目實(shí)現(xiàn)
本文主要介紹了spring?boot對(duì)敏感信息進(jìn)行加解密的項(xiàng)目實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04Maven 版本管理與 flatten-maven-plugin 插件的使用解析
這篇文章主要介紹了Maven 版本管理與 flatten-maven-plugin 插件的使用解析,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07spring的同一定時(shí)任務(wù)上一次的任務(wù)未結(jié)束前不會(huì)啟動(dòng)這次任務(wù)問(wèn)題
這篇文章主要介紹了spring的同一定時(shí)任務(wù)上一次的任務(wù)未結(jié)束前不會(huì)啟動(dòng)這次任務(wù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Java并發(fā)工具之CyclicBarrier使用詳解
這篇文章主要介紹了Java并發(fā)工具之CyclicBarrier使用詳解,CyclicBarrier是一個(gè)同步器,允許一組線程相互之間等待,直到到達(dá)某個(gè)公共屏障點(diǎn)(common barrier point),再繼續(xù)執(zhí)行,需要的朋友可以參考下2023-12-12使用SpringAop動(dòng)態(tài)獲取mapper執(zhí)行的SQL,并保存SQL到Log表中
這篇文章主要介紹了使用SpringAop動(dòng)態(tài)獲取mapper執(zhí)行的SQL,并保存SQL到Log表中問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03java 1.8 動(dòng)態(tài)代理源碼深度分析
下面小編就為大家?guī)?lái)一篇java 1.8 動(dòng)態(tài)代理源碼深度分析。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06Spring?Boot?3.x?集成?Feign的詳細(xì)過(guò)程
本文闡述了如何在SpringBoot3.x中集成Feign,以實(shí)現(xiàn)微服務(wù)之間的調(diào)用,主要步驟包括:搭建chain-common服務(wù),創(chuàng)建chain-starter/chain-feign-starter服務(wù),集成Feign到chain-system和chain-iot-channel服務(wù),配置Feign,感興趣的朋友一起看看吧2024-09-09