经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
Mybatis重置Criteria的正确姿势分享
来源:jb51  时间:2021/12/15 8:46:16  对本文有异议

Mybatis重置Criteria

开发中遇到Mybatis生成的Example通过调用createCriteria()来创建Criteria并设置查询条件的情况。

但是需要换一个查询条件再次查询时发现再次调用该方法“无效果"。

看到大多数的做法是通过new一个新的Example来查询,考虑到可能不是最好的或者最合理的做法,对此进行了简单研究。

发现问题原因如下

我们看下生成的Exmaple的源码:

  1. public Criteria createCriteria() {
  2. Criteria criteria = createCriteriaInternal();
  3. if (oredCriteria.size() == 0) {
  4. oredCriteria.add(criteria);
  5. }
  6. return criteria;
  7. }
  8. protected Criteria createCriteriaInternal() {
  9. Criteria criteria = new Criteria();
  10. return criteria;
  11. }

发现调用createCriteria(),虽然每次创建一个新的Criteria对象但是只有

  1. protected List<Criteria> oredCriteria

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

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

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

  1. public void or(Criteria criteria) {
  2. oredCriteria.add(criteria);
  3. }

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

两种方法:

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

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

  1. public List<Criteria> getOredCriteria() {
  2. return oredCriteria;
  3. }

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

  1. public void clear() {
  2. oredCriteria.clear();
  3. orderByClause = null;
  4. distinct = false;
  5. pageParam = null;
  6. }

得出一个结论

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

Mybatis的Criteria用法总结

在这里插入图片描述

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号