mybatis寫xml時(shí)數(shù)字類型千萬別用 !=‘‘(不為空串)進(jìn)行判斷的示例詳解
前言
最近項(xiàng)目內(nèi)更新數(shù)據(jù)時(shí),發(fā)現(xiàn)數(shù)字類型字段設(shè)置為0時(shí)不能正常的更新進(jìn)數(shù)據(jù)庫,我們打印了下mybatis的sql日志發(fā)現(xiàn)字段為0的sql沒有被拼接。
樣例
下面的是錯(cuò)誤示例 ❌
<update id="update" parameterType="com.chengfengfeng.test.domain.People">
update people
set
<if test="age!=null and age !=''">
age=#{age},
</if>,
modified = sysdate()
where user_id = #{userId}
</update>
age是個(gè)int類型的數(shù)據(jù),我們在寫age判斷的時(shí)候就增加上了判斷age!='',這個(gè)是存在問題的。
正確的示例 ✅
<update id="update" parameterType="com.chengfengfeng.test.domain.People">
update people
set
<if test="age!=null">
age=#{age},
</if>,
modified = sysdate()
where user_id = #{userId}
</update>
原因是什么呢
跟蹤了下代碼,發(fā)現(xiàn)在解析xml時(shí)數(shù)字類型會走下面的判斷
public abstract class OgnlOps implements NumericTypes {
//省略其他無用代碼
public static double doubleValue(Object value) throws NumberFormatException {
if (value == null) {
return 0.0D;
} else {
Class c = value.getClass();
if (c.getSuperclass() == Number.class) {
return ((Number)value).doubleValue();
} else if (c == Boolean.class) {
return (Boolean)value ? 1.0D : 0.0D;
} else if (c == Character.class) {
return (double)(Character)value;
} else {
String s = stringValue(value, true);
//這個(gè)位置會把'‘空串處理成0
return s.length() == 0 ? 0.0D : Double.parseDouble(s);
}
}
}
}
我們看上面最后一段代碼,會把''轉(zhuǎn)換成0.0D,那么我們的最開始的if判斷就變成了age != 0,所以當(dāng)我們把a(bǔ)ge設(shè)置為0時(shí),結(jié)果就變成了false,導(dǎo)致sql不會進(jìn)行拼接,更新數(shù)據(jù)失敗。
到此這篇關(guān)于mybatis寫xml時(shí)數(shù)字類型千萬別用 !=‘‘(不為空串)進(jìn)行判斷的示例詳解的文章就介紹到這了,更多相關(guān)mybatis寫xml數(shù)字類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot的@Value給靜態(tài)變量注入application.properties屬性值
這篇文章主要介紹了SpringBoot的@Value給靜態(tài)變量注入application.properties屬性值,Spring是一個(gè)開源的框架,主要是用來簡化開發(fā)流程,通過IOC,依賴注入(DI)和面向接口實(shí)現(xiàn)松耦合,需要的朋友可以參考下2023-05-05
SpringBoot整合atomikos實(shí)現(xiàn)跨庫事務(wù)的詳細(xì)方案
這篇文章主要介紹了SpringBoot整合atomikos實(shí)現(xiàn)跨庫事務(wù),業(yè)務(wù)主要涉及政府及企業(yè)且并發(fā)量不大,所以采用XA事務(wù),雖然性能有所損失,但是可以保證數(shù)據(jù)的強(qiáng)一致性,需要的朋友可以參考下2022-06-06
JMeter中的后端監(jiān)聽器的實(shí)現(xiàn)
本文主要介紹了JMeter中的后端監(jiān)聽器的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
如何構(gòu)建可重復(fù)讀取inputStream的request
這篇文章主要介紹了如何構(gòu)建可重復(fù)讀取inputStream的request,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
一個(gè)簡單的SpringBoot項(xiàng)目快速搭建詳細(xì)步驟
Spring Boot是由Pivotal團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來簡化新Spring應(yīng)用的初始搭建以及開發(fā)過程,下面這篇文章主要給大家介紹了一個(gè)簡單的SpringBoot項(xiàng)目快速搭建詳細(xì)步驟,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
Spring Security+Spring Data Jpa如何進(jìn)行安全管理
這篇文章主要介紹了Spring Security+Spring Data Jpa如何進(jìn)行安全管理,幫助大家更好的理解和學(xué)習(xí)Spring Security框架,感興趣的朋友可以了解下2020-09-09

