最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
spring boot mogodb多条件拼接的解决方法
时间:2018-08-23 编辑:猪哥 来源:一聚教程网
起因
当前我们使用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 ListgetClients(List codeAccountPeriods) { List 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 fields = new ArrayList ( Arrays.asList("accountPeriod", "code", "client", "taxProperty", "version")); for (String name : fields) { query.fields().include(name); } List clients = mongoTemplate.find(query, x); return clients;
有时解决问题的方法可以有多种,我们需要从另一个方面去考虑它。
相关文章
- SpringBoot自定义bean绑定解析 10-24
- Javaweb工程运行报错HTTP Status 404解决教程 10-20
- JAVA获取jvm和操作系统相关信息方法 10-20
- BeanFactory和FactoryBean的区别讲解 10-20
- 微信小程序的宿主环境实现教程 10-10
- dispatchEvent解决重叠元素响应事件教程 10-10