Mybatis重置Criteria的正確姿勢分享
Mybatis重置Criteria
開發中遇到Mybatis生成的Example通過調用createCriteria()來創建Criteria並設置查詢條件的情況。
但是需要換一個查詢條件再次查詢時發現再次調用該方法“無效果”。
看到大多數的做法是通過new一個新的Example來查詢,考慮到可能不是最好的或者最合理的做法,對此進行瞭簡單研究。
發現問題原因如下
我們看下生成的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; }
發現調用createCriteria(),雖然每次創建一個新的Criteria對象但是隻有
protected List<Criteria> oredCriteria
這個列表長度為0時才會添加,進去。
查看映射的xml文件時發現,查詢條件正是取自於oredCriteria。
隻有調用or時才添加到該集合中
public void or(Criteria criteria) { oredCriteria.add(criteria); }
我們想重置查詢條件怎麼辦?
兩種方法:
一種是隻清空Example的oredCriteria屬性。
那麼可以通過Example類中的getOredCriteria() 函數獲取該列表後通過clear方法清空。
public List<Criteria> getOredCriteria() { return oredCriteria; }
另外一種更徹底的方法,直接調用Example的clear() 方法,將exmple對象“重置”為初始狀態。
public void clear() { oredCriteria.clear(); orderByClause = null; distinct = false; pageParam = null; }
得出一個結論
遇到問題,多看源碼,多看官方文檔。
Mybatis的Criteria用法總結
用一對多內斂查詢的時候,有的老鐵提出left join in 但是我和同事商討結果是用代碼寫處各種list然後stream存到數據庫中,這樣一來把計算壓力從數據庫存入服務器,當並發量高瞭,這樣做的好處就體現在性能方面瞭。
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- MyBatis Generator生成的$ sql是否存在註入風險詳解
- mybatis example如何自動生成代碼 排序語句
- idea使用Mybatis逆向工程插件詳情
- MyBatis中criteria的or(或查詢)語法說明
- Mybatis Criteria使用and和or進行聯合條件查詢的操作方法