mybatisplus中EntityWrapper的常用方法
EntityWrapper的常用方法
#WHERE (issue_type = ?) AND (status = ? OR status = ? OR status = ?)
EntityWrapper wrapper=new EntityWrapper();
wrapper.eq("issue_type","缺陷").andNew().eq("status","提交").or()
.eq("status","激活").or().eq("status","解決");粗心遇到的EntityWrapper的一個(gè)坑
公司項(xiàng)目框架是SpringBoot為主題,整合了MyBatisPlus的數(shù)據(jù)庫(kù)框架,在Service進(jìn)行簡(jiǎn)單的單表查詢時(shí)一般直接使用EntityWrapper的包裝類進(jìn)行查詢,比較方便.
但在昨天工作的過(guò)程中發(fā)現(xiàn)一個(gè)查詢方法來(lái)來(lái)回回的出錯(cuò),查詢條件與預(yù)期不符,最終發(fā)現(xiàn)是一個(gè)wrapper中使用addFilterIfNeed時(shí)粗心導(dǎo)致的大坑!
Service層查詢語(yǔ)句:
EntityWrapper<PayTiXianApplyEntity> ew=new EntityWrapper<PayTiXianApplyEntity>();
? ? ? ? ew.eq(Util.isNotEmpty(params.getState()), "STATE", params.getState())
? ? ? ? ? ? ? ? //state不為空,根據(jù)state查詢
? ? ? ? ? ? ? ? .like(Util.isNotEmpty(params.getTxname()), "TXNAME", params.getTxname())
? ? ? ? ? ? ? ? .eq(Util.isNotEmpty(params.getTxmode()), "TXMODE", params.getTxmode())
? ? ? ? ? ? ? ? .like(Util.isNotEmpty(params.getTxserial()), "TXSERIAL", params.getTxserial())
? ? ? ? ? ? ? ? .addFilterIfNeed(Util.isNotEmpty(txtime), "DATE_FORMAT(TXTIME,'%Y-%m-%d')='" + txtime+"'")
? ? ? ? ? ? ? ? .addFilterIfNeed(Util.isEmpty(params.getState()),"state=1 or state=3 or state=4")
? ? ? ? ? ? ? ? //state為空,查詢state為1或2的記錄,即出納人審核通過(guò)和沒(méi)通過(guò)的記錄
? ? ? ? ? ? ? ? .orderBy("TXTIME", false);
Page<PayTiXianApplyEntity> page = this.selectPage(
? ? ? ? ? ? ? ? new Query<PayTiXianApplyEntity>(params).getPage(),ew);由于需求是,根據(jù)參數(shù)不同使用不同的查詢條件.state為空時(shí)需查詢表中所有state符合要求的記錄;state不為空,則根據(jù)state=參數(shù)來(lái)查詢.
為了省事,所以直接使用了wrapper,其實(shí)在MaBatis中使用條件判斷語(yǔ)句也是可以的.
原因
原因就出在為了省事,使用wrapper的addFilterIfNeed上.
出錯(cuò)的是這條語(yǔ)句:
.addFilterIfNeed(Util.isEmpty(params.getState()),"state=1 or state=3 or state=4")
由于一開(kāi)始是直接新建的new EntityWrapper的匿名對(duì)象,所以即使是debug也查不出錯(cuò)誤.為了看清SQL,我新建了一個(gè)對(duì)象ew,在debug過(guò)程中仔細(xì)看他的SQL屬性,最后發(fā)現(xiàn)了,在執(zhí)行這條語(yǔ)句時(shí),SQL只是簡(jiǎn)單的語(yǔ)句拼接.
也就是說(shuō),當(dāng)我state為null時(shí),這條查詢的語(yǔ)句是:(不能寫完整的語(yǔ)句,部分參數(shù)直接用#{}來(lái)代替)
SELECT * FROM 表名
WHERE TXNAME like #{txname}?
AND TXMODE=#{txmode}
AND TXSERIAL=#{txserial}
AND DATE_FORMAT(TXTIME,'%Y-%m-%d')=#{txtime}
AND state=1 or state=3 or state=4
ORDER BY TXTIME;發(fā)現(xiàn)問(wèn)題了吧!
由于addFilterIfNeed只是簡(jiǎn)單的語(yǔ)句拼接,所以即使我這一句寫在了一起,照樣給我原樣加上去的,所以導(dǎo)致查詢邏輯錯(cuò)誤,進(jìn)而引起查詢條件失效!
解決方案
解決方案很簡(jiǎn)單,只要在語(yǔ)句中加上括號(hào)即可
.addFilterIfNeed(Util.isEmpty(params.getState()),"(state=1 or state=3 or state=4)")
總結(jié):至此,此次遇到的大坑完整解決,也因此明白EntityWrapper中addFilterIfNeed的實(shí)現(xiàn)方式.之前沒(méi)發(fā)現(xiàn)這個(gè)問(wèn)題時(shí)來(lái)來(lái)回回改了好多次,都沒(méi)有解決問(wèn)題,直到發(fā)現(xiàn)根源!
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java 垃圾回收機(jī)制詳解(動(dòng)力節(jié)點(diǎn)Java學(xué)院整理)
在系統(tǒng)運(yùn)行過(guò)程中,會(huì)產(chǎn)生一些無(wú)用的對(duì)象,這些對(duì)象占據(jù)著一定的內(nèi)存,如果不對(duì)這些對(duì)象清理回收無(wú)用對(duì)象的內(nèi)存,可能會(huì)導(dǎo)致內(nèi)存的耗盡,所以垃圾回收機(jī)制回收的是內(nèi)存。下面通過(guò)本文給大家詳細(xì)介紹java垃圾回收機(jī)制,一起學(xué)習(xí)吧2017-02-02
Java CAS底層實(shí)現(xiàn)原理實(shí)例詳解
這篇文章主要介紹了Java CAS底層實(shí)現(xiàn)原理實(shí)例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
spring bean.xml文件p標(biāo)簽使用報(bào)錯(cuò)的解決
這篇文章主要介紹了spring bean.xml文件p標(biāo)簽使用報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
解決IDEA報(bào)錯(cuò)java無(wú)效的目標(biāo)發(fā)行版:22
在使用IDEA編譯項(xiàng)目時(shí),可能會(huì)遇到JDK版本不一致的錯(cuò)誤,這篇文章主要介紹了解決IDEA報(bào)錯(cuò)java無(wú)效的目標(biāo)發(fā)行版:22的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10
Java求素?cái)?shù)和最大公約數(shù)的簡(jiǎn)單代碼示例
這篇文章主要介紹了Java求素?cái)?shù)和最大公約數(shù)的簡(jiǎn)單代碼示例,其中作者創(chuàng)建的Fraction類可以用來(lái)進(jìn)行各種分?jǐn)?shù)運(yùn)算,需要的朋友可以參考下2015-09-09
java數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹(shù)
這篇文章主要為大家詳細(xì)介紹了java數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
Mybatis in條件傳參的三種實(shí)現(xiàn)方式(直接$,List,[])
這篇文章主要介紹了Mybatis in條件傳參的三種實(shí)現(xiàn)方式(直接$,List,[]),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Java 靜態(tài)數(shù)據(jù)初始化的示例代碼
這篇文章主要介紹了Java 靜態(tài)數(shù)據(jù)初始化的示例代碼,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下2020-09-09

