java – 如何检查该值是否等于列表中的至少一个字段?
发布时间:2020-12-15 04:41:25 所属栏目:Java 来源:网络整理
导读:我有这样的方法: for (String fieldName : fieldArray) { Query query = new Query(); query.addCriteria(Criteria.where("data." + fieldName).is("some_constant")); if (mongoTemplate.find(query,DataPoint.class).size() 0) { return true; }}return f
我有这样的方法:
for (String fieldName : fieldArray) { Query query = new Query(); query.addCriteria(Criteria.where("data." + fieldName).is("some_constant")); if (mongoTemplate.find(query,DataPoint.class).size() > 0) { return true; } } return false; 这段代码看起来效率低下,因为它访问db这么多fieldArray的大小. 有没有办法用单个查询替换它? 解决方法
在我看来,你可以使用
public Criteria orOperator(Criteria... criteria)
它应该是这样的: List<Criteria> criterias = new ArrayList<>(); for (String fieldName : fieldArray) { //Create the criterias like you want criterias.add(Criteria.where("data." + fieldName).is("some_constant")); } Query query = new Query( new Criteria().orOperator( criterias.toArray( //convert the list into an Criteria[] for the varargs parameter new Criteria[criterias.size()] ) ) ); 这将创建一个Criteria列表,??用于生成Criteria实例,如果一个条件有效(OR操作,一个true就足够了),该实例将有效. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |