mybatis?傳入null值的解決方案
mybatis 傳入null值解決
前端傳入兩個(gè)值,如果其中一個(gè)為null時(shí),很多時(shí)候我們都很困惑,明明傳入的是null,為啥mybatis 的xml文件中的if條件判斷無效?
public String getPersonInfo(@PathParam("Name") String Name, @PathParam("IDCard") String IDCard)
dao層
public List<Map> getPersonInfo(@Param("name") String name, @Param("idcard") String idcard);
xml文件內(nèi)容
<if test="name == null or name == '0'.toString()">? ? ? <![CDATA[ and (b.identity_id = #{idcard,javaType=String,jdbcType=VARCHAR}) ? ? group by name,id_card,birthTime,sex ?]]>? </if>
每次執(zhí)行都是失敗的,網(wǎng)上很多都說要在dao層添加@param注解和xml文件內(nèi)容中要加入jdbcType類型就能解決,最后還是沒解決
其實(shí)還有一個(gè)點(diǎn)忽略了,就是傳入時(shí)的null值其實(shí)是個(gè)字符串null,根本就不是null,它是個(gè)字符串null
? ? ? ? if (Name == null || "null".equalsIgnoreCase(Name)) { ? ? ? ? ? ? Name = null; ? ? ? ? } ? ? ? ? if (IDCard == null || "null".equalsIgnoreCase(IDCard)) { ? ? ? ? ? ? IDCard = null; ? ? ? ? }
問題解決!
mybatis 注入老是為null
今天遇到個(gè)很弱智的問題,以此記錄!時(shí)刻提醒自己
public int delExhibion(List<String> ids){ Integer result = null; ExhibitionManager exhibitionManager = new ExhibitionManager(); for (String id : ids){ exhibitionManager.setId(id); exhibitionManager.setDelFlag("1"); result += exhibitionManagerMapper.delete(id); } return result; }
發(fā)現(xiàn)老是執(zhí)行 delete 的時(shí)候 ,老是報(bào) 空指針異常
然后嘗試使用: @Param 給參數(shù)加上命令
int delete(@Param("id") String id); ?
結(jié)果還是不行,
然后在嘗試使用:對象傳參,這樣總該注入進(jìn)去了吧
int delete(Object dx);
結(jié)果還是不行,
然后在嘗試使用:Mybatis 單個(gè)參數(shù)動(dòng)態(tài)語句引用:
是當(dāng)我們的參數(shù)為String時(shí),在sql語句中#{id} 會(huì)去我們傳進(jìn)來的參數(shù)調(diào)getId()方法獲取參數(shù),很明顯,String沒有對應(yīng)的方法,所以報(bào)錯(cuò)了,那我們這里要如何引用id呢,需要采用下面的寫法:
<delete id="delete" parameterType="java.lang.String" > ? ? ? ? ? ?SELECT * FROM table ? ? ? ? ?<where> ? ? ? ? ? ? ? ? ? ? ?<if test="_parameter != null"> ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? AND id= #{id} ? ? ? ? ? ? ? ? ? ? ?</if> ? ? ? ? ? ?</where> ? </select>
單Mybatis傳參為單個(gè)參數(shù)時(shí),在sql語句中需要使用 _parameter 來引用這個(gè)參數(shù)
結(jié)果還是不行。
終于過了一會(huì)兒,看代碼時(shí)突然頓悟
? ? public int delExhibion(List<String> ids){ ? ? ? ? Integer result = null; ? ? ? ? for (String id : ids){ ? ? ? ? ? ? ?result += exhibitionManagerMapper.delete(id); ? ? ? ? } ? ? ? ? return result; ? ? }
Integer result 我給他設(shè)置默認(rèn)值 為null, 并且還讓 reuslt 這個(gè)對象 result +=
加等于在執(zhí)行數(shù)據(jù)庫操作返回結(jié)果時(shí) 用 result 去接收。 這不就一定是空指針了嗎。
我給 Integer result = 0; 設(shè)置個(gè)默認(rèn)值為0 那也不會(huì)出現(xiàn)這種情況!
或者 result = 給result 初始化賦值 也不會(huì)報(bào) 空指針異常! 不過這樣做在我的業(yè)務(wù)中是不對的哦。 只是不會(huì)報(bào)錯(cuò). 但是獲取不到我想要的執(zhí)行成功條數(shù)
Integer result = null; result = ?exhibitionManagerMapper.delete(id);
真的是被自己氣到了。以此記錄!時(shí)刻提醒自己
?public int delExhibion(List<String> ids){ ? ? ? ? Integer result = 0; ? ? ? ? for (String id : ids){ ? ? ? ? ? ? ?result += exhibitionManagerMapper.delete(id); ? ? ? ? } ? ? ? ? return result; ? ? }
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
mybatis-plus的自動(dòng)填充時(shí)間的問題(添加到數(shù)據(jù)庫的時(shí)間比當(dāng)前時(shí)間多4個(gè)小時(shí))
這篇文章主要介紹了mybatis-plus的自動(dòng)填充時(shí)間的問題(添加到數(shù)據(jù)庫的時(shí)間比當(dāng)前時(shí)間多4個(gè)小時(shí)),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09Java數(shù)據(jù)結(jié)構(gòu)和算法之冒泡排序(動(dòng)力節(jié)點(diǎn)Java學(xué)院整理)
冒泡排序(Bubble Sort)是一種簡單的排序算法。本文重點(diǎn)給大家介紹java數(shù)據(jù)結(jié)構(gòu)和算法之冒泡排序,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-04-04java8 LocalDate LocalDateTime等時(shí)間類用法實(shí)例分析
這篇文章主要介紹了java8 LocalDate LocalDateTime等時(shí)間類用法,結(jié)合具體實(shí)例形式分析了LocalDate、LocalTime、LocalDateTime等日期時(shí)間相關(guān)類的功能與具體使用技巧,需要的朋友可以參考下2017-04-04MyBatis使用動(dòng)態(tài)SQL標(biāo)簽的小陷阱
MyBatis是一個(gè)支持普通SQL查詢,存儲(chǔ)過程和高級映射的優(yōu)秀持久層框架,MyBatis越來越受大家的喜愛了。下面給大家分享MyBatis使用動(dòng)態(tài)SQL標(biāo)簽的小陷阱,感興趣的朋友一起看看吧2016-10-10SpringBoot整合Canal與RabbitMQ監(jiān)聽數(shù)據(jù)變更記錄
這篇文章主要介紹了SpringBoot整合Canal與RabbitMQ監(jiān)聽數(shù)據(jù)變更記錄,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09Spring Boot 集成 Mybatis Plus 自動(dòng)填充字段的實(shí)例詳解
這篇文章主要介紹了Spring Boot 集成 Mybatis Plus 自動(dòng)填充字段,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03