服务器之家

服务器之家 > 正文

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

时间:2021-05-26 12:15     来源/作者:我们都是和自己赛跑的人

起因

当前我们使用mongodb进行查询时,有时我们的条件是分块生成的,它可能来自一个列表里,我们的条件需要根据列表去返回数据,这里有个问题,如果遍历列表,然后每次都去从mongodb里查询数据 ,这种性能显然是不好的,我们需要把条件进行拼接,一次把数据查询出来!

分析

使用criteria这个对象去构建查询条件,使用oroperator来组合多个criteria实例,最终将列表里所有条件拼接出来,从返回查询一次即可返回全部数据 。

?
1
criteria[] criterias = criterialist.toarray(new criteria[criterialist.size()]); criteria criteria = new criteria(); criteria.oroperator(criterias); query query = query.query(criteria);

实现

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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多条件拼接的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:http://www.cnblogs.com/lori/p/9488979.html

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部