springboot~mogodb多条件拼接

原由

当前咱们使用mongodb进行查询时,有时咱们的条件是分块生成的,它可能来自一个列表里,咱们的条件须要根据列表去返回数据,这里有个问题,若是遍历列表,而后每次都去从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);code

实现

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;

有时解决问题的方法能够有多种,咱们须要从另外一个方面去考虑它。对象

相关文章
相关标签/搜索