spring boot mogodb多条件拼接的解决方法
程序员文章站
2024-02-22 08:11:46
起因
当前我们使用mongodb进行查询时,有时我们的条件是分块生成的,它可能来自一个列表里,我们的条件需要根据列表去返回数据,这里有个问题,如果遍历列表,然后每次都去从...
起因
当前我们使用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;
有时解决问题的方法可以有多种,我们需要从另一个方面去考虑它。
总结
以上所述是小编给大家介绍的spring boot mogodb多条件拼接的解决方法,希望对大家有所帮助