Mybatis重置Criteria的正确姿势分享

网友投稿 286 2022-09-09


Mybatis重置Criteria的正确姿势分享

目录Mybatis重置Criteria发现问题原因如下我们想重置查询条件怎么办?得出一个结论Mybatis的Criteria用法总结

Mybatis重置Criteria

开发中遇到Mybatishttp://生成的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 oredCriteria

这个列表长度为0时才会添加,进去。

查看映射的xml文件时发现,查询条件正是取自于oredCriteria。

只有调用or时才添加到该集合中

public void or(Criteria criteria) {

oredCriteria.add(criteria);

}

我们想重置查询条件怎么办?

两种方法:

一种是只清空Example的oredCriteria属性。

那么可以通过Example类中的getOredCriteria() 函数获取该列表后通过clear方法清空。

public List getOredCriteria() {

return oredCriteria;

fIrOkM }

另外一种更彻底的方法,直接调用Example的clear() 方法,将exmple对象“重置”为初始状态。

public void clear() {

oredCriteria.clear();

orderByClausehttp:// = null;

distinct = false;

pageParam = null;

}

得出一个结论

遇到问题,多看源码,多看官方文档。

Mybatis的Criteria用法总结

用一对多内敛查询的时候,有的老铁提出left join in 但是我和同事商讨结果是用代码写处各种list然后stream存到数据库中,这样一来把计算压力从数据库存入服务器,当并发量高了,这样做的好处就体现在性能方面了。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:RFC2563
下一篇:802.1x协议解析(802.1s协议)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~