加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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就足够了),该实例将有效.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读