好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

起因

当前我们使用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

查看更多关于spring boot mogodb多条件拼接的解决方法的详细内容...

  阅读:52次