Mybatis重置Criteria的正確姿勢(shì)分享
Mybatis重置Criteria
開發(fā)中遇到Mybatis生成的Example通過(guò)調(diào)用createCriteria()來(lái)創(chuàng)建Criteria并設(shè)置查詢條件的情況。
但是需要換一個(gè)查詢條件再次查詢時(shí)發(fā)現(xiàn)再次調(diào)用該方法“無(wú)效果"。
看到大多數(shù)的做法是通過(guò)new一個(gè)新的Example來(lái)查詢,考慮到可能不是最好的或者最合理的做法,對(duì)此進(jìn)行了簡(jiǎn)單研究。
發(fā)現(xiàn)問(wèn)題原因如下
我們看下生成的Exmaple的源碼:
public Criteria createCriteria() {
Criteria criteria = createCriteriaInternal();
if (oredCriteria.size() == 0) {
oredCriteria.add(criteria);
}
return criteria;
}
protected Criteria createCriteriaInternal() {
Criteria criteria = new Criteria();
return criteria;
}
發(fā)現(xiàn)調(diào)用createCriteria(),雖然每次創(chuàng)建一個(gè)新的Criteria對(duì)象但是只有
protected List<Criteria> oredCriteria
這個(gè)列表長(zhǎng)度為0時(shí)才會(huì)添加,進(jìn)去。
查看映射的xml文件時(shí)發(fā)現(xiàn),查詢條件正是取自于oredCriteria。
只有調(diào)用or時(shí)才添加到該集合中
public void or(Criteria criteria) {
oredCriteria.add(criteria);
}
我們想重置查詢條件怎么辦?
兩種方法:
一種是只清空Example的oredCriteria屬性。
那么可以通過(guò)Example類中的getOredCriteria() 函數(shù)獲取該列表后通過(guò)clear方法清空。
public List<Criteria> getOredCriteria() {
return oredCriteria;
}
另外一種更徹底的方法,直接調(diào)用Example的clear() 方法,將exmple對(duì)象“重置”為初始狀態(tài)。
public void clear() {
oredCriteria.clear();
orderByClause = null;
distinct = false;
pageParam = null;
}
得出一個(gè)結(jié)論
遇到問(wèn)題,多看源碼,多看官方文檔。
Mybatis的Criteria用法總結(jié)

用一對(duì)多內(nèi)斂查詢的時(shí)候,有的老鐵提出left join in 但是我和同事商討結(jié)果是用代碼寫處各種list然后stream存到數(shù)據(jù)庫(kù)中,這樣一來(lái)把計(jì)算壓力從數(shù)據(jù)庫(kù)存入服務(wù)器,當(dāng)并發(fā)量高了,這樣做的好處就體現(xiàn)在性能方面了。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot X-Accel-Redirect 大文件下載實(shí)現(xiàn)
本文主要介紹了springboot X-Accel-Redirect 大文件下載實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
Springboot集成Ehcache3實(shí)現(xiàn)本地緩存的配置方法
EhCache是一個(gè)純Java的進(jìn)程內(nèi)緩存框架,是 Hibernate 中默認(rèn)的 CacheProvider,同Redis一樣,EhCache 不是純內(nèi)存緩存,它支持基于內(nèi)存和磁盤的二級(jí)緩存,本文介紹Springboot集成Ehcache3實(shí)現(xiàn)本地緩存的配置方法,感興趣的朋友一起看看吧2024-04-04
SpringBoot+Spring Security+JWT實(shí)現(xiàn)RESTful Api權(quán)限控制的方法
這篇文章主要介紹了SpringBoot+Spring Security+JWT實(shí)現(xiàn)RESTful Api權(quán)限控制的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
java json 省市級(jí)聯(lián)實(shí)例代碼
這篇文章介紹了java json 省市級(jí)聯(lián)實(shí)例代碼,有需要的朋友可以參考一下2013-09-09
Java實(shí)現(xiàn)自定義語(yǔ)言和表達(dá)式解析的解釋器模式
Java解釋器設(shè)計(jì)模式通過(guò)解析自定義語(yǔ)言和表達(dá)式,實(shí)現(xiàn)對(duì)復(fù)雜邏輯的處理,提高程序可擴(kuò)展性和靈活性。它將語(yǔ)法解析和執(zhí)行過(guò)程分離,通過(guò)抽象語(yǔ)法樹和解釋器實(shí)現(xiàn)對(duì)語(yǔ)言和表達(dá)式的解析和求值,避免了硬編碼和復(fù)雜的條件判斷,提高了程序的可讀性和可維護(hù)性2023-04-04
MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報(bào)錯(cuò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06

