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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 任正非公开信深度解读:两年怎样改变了华为?「建议收藏」

    任正非公开信深度解读:两年怎样改变了华为?「建议收藏」任正非公开信深度解读:两年怎样改变了华为?

  • pycharm搭建python环境_pycharm如何配置编译环境

    pycharm搭建python环境_pycharm如何配置编译环境1.安装python27双击执行python-2.7.15.msi,选择装到根目录,建议d:\Python27。一路下一步,直到完成。安装完成之后,打开cmd,输入:python,如果显示以下内容则说明安装python成功如果提示命令不存在则需要设置环境变量。windows:右键我的电脑–属性–高级系统设置–高级–环境变量–系统变量找到path项,加上值,D:\Python27;D:\P…

  • 一千行 MySQL 学习笔记

    一千行 MySQL 学习笔记

    2021年10月25日
  • C++星火03_valist用法

    C++星火03_valist用法1背景函数的参数一般是用栈的形式从右向左进行存储的,所以提取时候是从左向右提取例:#includeusingnamespacestd;voidfun(intnCnt,…){int*pTemp=&nCnt;pTemp++;for(inti=0;i{coutpTemp++;}cout}

    2022年10月27日
  • 文件读取(FileInputStream 读取本地文件)

    文件读取(FileInputStream 读取本地文件)使用FileInputStream读取本地文件(图片、视频、音乐、文档资料)二进制文件、文本文件1.在物理存储上上没有什么区别,存在硬盘上都是以二进制方式存储2.解释数据的逻辑不同,程序读取文本文件,可以以字符方式读取,也可以以字节读取,将读取的数据解释为ASCII或者unicode编码;当程序读取二进制文件,以字节方式读取,对读取数据的解释由读取数据而定,如读取图片时,需要了解文件的结…

  • UDP协议支持广播发送数据_tcp协议建立连接的过程

    UDP协议支持广播发送数据_tcp协议建立连接的过程UDP(用户数据报协议)是OSI(OpenSystemInterconnection,开放式系统互联)参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务。目录什么是UDP协议?UDP协议数据传输原理DatagramPacket类DatagramSocket类UDP协议网络通信客户端服务器程序服务器端程序客户端程序Hello!大家好!我是灰小猿。之前和大家分享了使用TCP协议进行网络通信的过程,想了解的小伙伴可以看我的这篇文章《Java利.

发表回复

您的电子邮箱地址不会被公开。

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