欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

spring boot mogodb多条件拼接的解决方法

时间:2021-04-10 08:51:44|栏目:JAVA代码|点击:

起因

当前我们使用mongodb进行查询时,有时我们的条件是分块生成的,它可能来自一个列表里,我们的条件需要根据列表去返回数据,这里有个问题,如果遍历列表,然后每次都去从mongodb里查询数据 ,这种性能显然是不好的,我们需要把条件进行拼接,一次把数据查询出来!

分析

使用Criteria这个对象去构建查询条件,使用orOperator来组合多个Criteria实例,最终将列表里所有条件拼接出来,从返回查询一次即可返回全部数据 。

Criteria[] criterias = criteriaList.toArray(new Criteria[criteriaList.size()]); Criteria criteria = new Criteria(); criteria.orOperator(criterias); Query query = Query.query(criteria);

实现

private List<x> getClients(List<CodeAccountPeriod> codeAccountPeriods) {
 List<Criteria> criteriaList = new ArrayList<>();
  for (CodeAccountPeriod codeAccountPeriod : codeAccountPeriods) {
   criteriaList.add(where("accountPeriod").is(codeAccountPeriod.getAccountPeriod())
     .and("code").is(codeAccountPeriod.getCode())
   );
  }
  Criteria[] criterias = criteriaList.toArray(new Criteria[criteriaList.size()]);
  Criteria criteria = new Criteria();
  criteria.orOperator(criterias);
  Query query = Query.query(criteria);
  List<String> fields = new ArrayList<String>(
    Arrays.asList("accountPeriod", "code", "client", "taxProperty", "version"));
  for (String name : fields) {
   query.fields().include(name);
  }
  List<x> clients = mongoTemplate.find(query, x);
return clients;

有时解决问题的方法可以有多种,我们需要从另一个方面去考虑它。

总结

上一篇:Spring整合MyBatis的三种方式

栏    目:JAVA代码

下一篇:基于JWT实现SSO单点登录流程图解

本文标题:spring boot mogodb多条件拼接的解决方法

本文地址:http://www.codeinn.net/misctech/98289.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有