mybatis查詢字段為null設(shè)置為0的操作
背景
使用mybatis查詢(mysql)時(shí),會(huì)使用多個(gè)double字段做相加,但是呢,其中幾個(gè)字段有可能是null,會(huì)拋空指針。
解決方法
自動(dòng)生成的mybatis mapper文件長這樣
<sql id="Base_Column_List"> ID, PREPAYMENT_FEE </sql>
修改它
<sql id="Base_Column_List"> ID, ifnull(PREPAYMENT_FEE,0) as PREPAYMENT_FEE </sql>
補(bǔ)充:mybatis中0和null關(guān)系處理
最近在項(xiàng)目開發(fā)中,mybatis遇到一個(gè)很奇怪的問題,因?yàn)橄朐诤笈_(tái)傳一個(gè)int型0插入到數(shù)據(jù),卻被識(shí)別成了null。
后面,排除問題時(shí),查到mybatis源碼對(duì)其進(jìn)行了強(qiáng)制定義。
所以解決問題可以改造mybatis源碼,或者簡(jiǎn)單的做以下處理:
<insert id="insertDemo" parameterType="java.util.Map">
INSERT INTO
TABLE
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="importRow != null and importRow != '' or importRow ==0 ">
IMPORT_ROW,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="importRow != null and importRow != '' or importRow ==0 ">
#{importRow},
</if>
</trim>
</insert>
增強(qiáng)判斷添加 or importRow ==0
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
淺談HBase在SpringBoot項(xiàng)目里的應(yīng)用(含HBaseUtil工具類)
這篇文章主要介紹了淺談HBase在SpringBoot項(xiàng)目里的應(yīng)用(含HBaseUtil工具類),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10
Java Annotation(Java 注解)的實(shí)現(xiàn)代碼
本篇文章介紹了,Java Annotation(Java 注解)的實(shí)現(xiàn)代碼。需要的朋友參考下2013-05-05
學(xué)習(xí)SpringBoot容器功能及注解原理
這篇文章主要介紹了學(xué)習(xí)SpringBoot容器功能及注解原理,文中通過詳細(xì)的代碼示例對(duì)SpringBoot容器功能及注解原理進(jìn)行了解析,有需要的朋友可以借鑒參考下2021-09-09
SpringMVC 接收前端傳遞的參數(shù)四種方式小結(jié)
這篇文章主要介紹了SpringMVC 接收前端傳遞的參數(shù)四種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
Maven?pom.xml文件獲取當(dāng)前時(shí)間戳方式
這篇文章主要介紹了Maven?pom.xml文件獲取當(dāng)前時(shí)間戳方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
java如何不通過構(gòu)造函數(shù)創(chuàng)建對(duì)象(Unsafe)
這篇文章主要介紹了java如何不通過構(gòu)造函數(shù)創(chuàng)建對(duì)象(Unsafe)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03

