MongoTemplate 条件查询

新手上路,请多包涵

我正在根据多个参数生成一个复杂的 Mongo 查询。我想用 Criteria 助手类制定的标准之一是:

 {"field1": {$exists: true, $ne: false}}

我试图做到这一点:

 Criteria.where("field1").is(Criteria.where("$ne").is(false).and("$exists").is(true))

但它会产生:

 { "field1" : { $java : org.springframework.data.mongodb.core.query.Criteria@23864e60 }

那么, 如何实现我需要的确切查询呢? 我不能对该查询字符串进行硬编码,因为这些类型标准是为 field1,…fieldN 动态生成的,然后与 $or 结合:

 statusCriteria = statusCriteria.orOperator(criterias.toArray(new Criteria[criterias.size()]));

原文由 Aeteros 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.2k
2 个回答

由于您不能使用 Criteria.and() 将多个条件添加到同一字段中,因此使用 Criteria.andOperator() 如下:

 Query query = new Query();
query.addCriteria(
    new Criteria().andOperator(
        Criteria.where("field1").exists(true),
        Criteria.where("field1").ne(false)
    )
);

List<Foo> result = mongoTemplate.find(query, Foo.class);
System.out.println("query - " + query.toString());

for (Foo foo : result) {
    System.out.println("result - " + foo);
}

原文由 chridam 发布,翻译遵循 CC BY-SA 3.0 许可协议

@Document(collection="student")
public class Student {
    private String id;
    private String name;
    private List<String> subjects;
}

在某个科目中搜索已选修该科目的学生名单。

 @Query("{'subjects':{$elemMatch:{$in:?0}}}")
public List<Student> getDrugByBrand(String[] subjects);

以上工作正常,但我想创建查询条件。

任何人都可以将 {‘subjects’:{\(elemMatch:{\)in:?0}}} 转换为标准

我正在尝试这样,但它不起作用

if(subject != null && ! subject()){
    criteria.add(Criteria.where("subjects")
            .elemMatch(Criteria.where("--what to put here for index--")
            .regex(subject,"i")
    ));
}

原文由 amitabh priyadarshi 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题