zoukankan      html  css  js  c++  java
  • springboot~mogodb多条件拼接

    起因

    当前我们使用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;
    

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

  • 相关阅读:
    处理emacs-org模式TODO的一个脚本
    MYSQL 数据类型
    Redis命令学习-Transaction(事务)
    成都青羊考场科目二考试分享
    地图入门_坐标系统
    microsoft SQL server,错误2
    搭建个人博客 方式2 使用jekyll
    WIN10 10招
    java正則表達式总结
    图解hdu5301Buildings
  • 原文地址:https://www.cnblogs.com/lori/p/9488979.html
Copyright © 2011-2022 走看看