起因


当前我们使用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;
有时解决问题的方法可以有多种,我们需要从另一个方面去考虑它。

友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:ixiaoyang8@qq.com
QQ群:637538335
关注微信