springboot~mogodb多条件拼接

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;

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

转载于:https://www.cnblogs.com/lori/p/9488979.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101483.html原文链接:https://javaforall.net

(0)
上一篇 2021年6月10日 下午9:00
下一篇 2021年6月10日 下午10:00


相关推荐

  • windows7 python 指定源组播 10049_试图绑定到特定的外部ip :: [Errno 10049]请求的地址在其上下文中无效无法打开socket-(python 2.7)…[通俗易懂]

    windows7 python 指定源组播 10049_试图绑定到特定的外部ip :: [Errno 10049]请求的地址在其上下文中无效无法打开socket-(python 2.7)…[通俗易懂]socket.INADDR_ANY等于socket.bind(‘0.0.0.0’)如果绑定到“0.0.0.0”可以监听所有接口(可用)MoxaTCP示例:importsocket,timeimportthread#Exampleclientclass_client:def__init__(self):self.status=Falsedefrun(self,clientso…

    2026年4月15日
    4
  • C语言学习——指针精华(3)工程项目复习

    C语言学习——指针精华(3)工程项目复习编程题一、定义一个数组,从键盘输入10个整数,将10个数字中的最大值和最小值进行位置交换 (使用指针的方式)。代码如下:#include”pch.h”#include<stdio.h>void SWAP(int*p1, int*p2);int main(){ int a[10]; for (int i = 0; i < 10; i++) { scanf_…

    2022年8月18日
    7
  • SpringCloud微服务架构体系

    SpringCloud微服务架构体系转自 https dalin blog csdn net article details 什么是微服务 1 1 架构演进架构的发展历程是从单体式架构 到分布式架构 到 SOA 架构 再到微服务架构 图 1 架构演进 单体架构 未做任何拆分的 JavaWeb 程序 图 2 单体架构示意图 分布式架构 按照业务垂直划分 每个业务都是单体架构 通过 API 互相调用 图 3 分布式架构示意图 SOA 架构 SOA 是一种面向服务的架构 其应用程序的不同组件通

    2026年3月18日
    1
  • linux挂载ipsan存储,centos系统ISCSI挂载IPSAN存储

    linux挂载ipsan存储,centos系统ISCSI挂载IPSAN存储先用一台电脑连接 IPSAN 管理端口进去配置阵列配置完成后把 IPSAN 的 ISCSI 接口连接到服务器网口 maniscsiadm 查看可以查看是否安装了 iscsiadmyum yinstall iscsi 命令安装 iscsiadm 然后在服务器上输入 iscsiadm mdiscovery tsendtargets p169 254 194 201 3260 169 254 19

    2026年3月16日
    2
  • 用JSP做个简单的登录注册页面

    用JSP做个简单的登录注册页面用 JSP 做个简单的登录注册页面第一步先分析整个过程 然后得出大概思路 首先 进入登录页面 login jsp 如下 我们是没有账号的所以需要注册账号 所以这时候必须有一个注册页面 register jsp 如下紧接着注册成功后跳转成功页面 这时我们需要一个注册成功的页面 registersucc jsp 如下 点击返回页面后 我们就可以在登录页面登录 然后登录时有登录成功和登录失败的页面 所以还要再写两个 loginsuccess jsploginfail jsp 如下

    2026年3月18日
    2
  • 水仙花数的判断(JAVA)

    水仙花数的判断(JAVA)水仙花数 JAVA 水仙花数的判断 JAVA 水仙花数的判断 JAVA 用户输入一个数 判断是否是 水仙花数 所谓 水仙花数 是指一个三位数 其各位数字立方和等于该数本身 题目分析水仙花数是一个三位数 将用户输入的三位数拆分成为单独的个位 十位 百位 对三个数字分别进行三次方运算 然后对运算后的三个数进行求和 如果运算得到的结果与用户输入的三位数相等 则说明该数为水仙花数 如果不等则说明不是 代码分析键盘输入需要用到 Scanner Scanner 是 JDK 中封装的一个类 该类的职责

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号