Mybatis重置Criteria的正确姿势分享
程序员文章站
2023-12-31 13:24:40
目录mybatis重置criteria发现问题原因如下我们想重置查询条件怎么办?得出一个结论mybatis的criteria用法总结mybatis重置criteria开发中遇到mybatis生成的ex...
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存到数据库中,这样一来把计算压力从数据库存入服务器,当并发量高了,这样做的好处就体现在性能方面了。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。