spring boot mogodb多条件拼接的解决方法

网友投稿 320 2023-01-23


spring boot 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 getClients(List codeAccountPeriods) {

List criteriaList = new ArrayList<>();

for (CodeAccountPeriod codeAccountPeriod : codeAccountPeriods) {

criteriaList.add(where("accountPeriod").is(codeAccountPeriod.getAccountPeriod())

.and("code").is(codeAccountPeriod.getCode())

);

}

Criteria[] criterias =http:// 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;

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

总结

以上所述是给大家介绍的spring boot mogodb多条件拼接的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:浅谈关于spring profile的误解
下一篇:音频接口自动化测试(接口测试和接口自动化测试区别)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~