时间:2021-05-19
起因
当前我们使用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 boot mogodb多条件拼接的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.什么是spring-boot-devtoolsspring-boot-devtools是spring-boot项目开发时的一个热部署工具,安装了spring
一)spring-boot-starter命名规则自动配置模块命名规则:xxx-spring-boot,如:aspectlog-spring-boot启动器命名
1.加入mybatis-spring-boot-stater的Maven依赖org.mybatis.spring.bootmybatis-spring-boot
SQL多条件查询以后我们做多条件查询,一种是排列结合,另一种是动态拼接SQL如:我们要有两个条件,一个日期@addDate,一个是@name第一种写法是if(@
电脑启动无限进入bios的解决方法是: 1、进入bios以后,找到上面的BOOT选项; 2、进入后,把boot下面的lanremoteboot设置为关闭;