Mybatis重置Criteria的正確姿勢(shì)分享
Mybatis重置Criteria
開發(fā)中遇到Mybatis生成的Example通過調(diào)用createCriteria()來(lái)創(chuàng)建Criteria并設(shè)置查詢條件的情況。
但是需要換一個(gè)查詢條件再次查詢時(shí)發(fā)現(xiàn)再次調(diào)用該方法“無(wú)效果"。
看到大多數(shù)的做法是通過new一個(gè)新的Example來(lái)查詢,考慮到可能不是最好的或者最合理的做法,對(duì)此進(jìn)行了簡(jiǎn)單研究。
發(fā)現(xià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屬性。
那么可以通過Example類中的getOredCriteria() 函數(shù)獲取該列表后通過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é)論
遇到問題,多看源碼,多看官方文檔。
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)文章
Spring Boot支持Crontab任務(wù)改造的方法
這篇文章主要介紹了Spring Boot支持Crontab任務(wù)改造的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2019-01-01
Java實(shí)現(xiàn)高并發(fā)秒殺的幾種方式
高并發(fā)場(chǎng)景在現(xiàn)場(chǎng)的日常工作中很常見,本文主要介紹了Java實(shí)現(xiàn)高并發(fā)秒殺的幾種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
關(guān)于Spring項(xiàng)目對(duì)JDBC的支持與基本使用詳解
這段時(shí)間一直在觀看Spring框架,所以下面這篇文章主要給大家介紹了關(guān)于Spring項(xiàng)目對(duì)JDBC的支持與基本使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
Quarkus中RESTEasy?Reactive集成合并master分支
這篇文章主要為大家介紹了Quarkus中RESTEasy?Reactive集成合并master分支的詳細(xì)作用分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02
SpringMVC Controller解析ajax參數(shù)過程詳解
這篇文章主要介紹了SpringMVC Controller解析ajax參數(shù)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
spring cloud gateway 限流的實(shí)現(xiàn)與原理
這篇文章主要介紹了spring cloud gateway 限流的實(shí)現(xiàn)與原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-12-12
mybatis-plus QueryWrapper 添加limit方式
這篇文章主要介紹了mybatis-plus QueryWrapper 添加limit方式,具有很好的參考價(jià)值,希望對(duì)大家有所2022-01-01
springboot?log4j2日志框架整合與使用過程解析
這篇文章主要介紹了springboot?log4j2日志框架整合與使用,包括引入maven依賴和添加配置文件log4j2-spring.xml的相關(guān)知識(shí),需要的朋友可以參考下2022-05-05

