Spring 数据 mongo 在数组中使用正则表达式查询

Spring data mongo query with regex within an array

我有一个结构有点像这样的集合:

{  
  "organization" : "Org1",  
  "active" : true,  
  "fields" : [  
  {  
    "key" : "key1",  
    "value" : "table"   
  },  
  {  
    "key" : "key2",  
    "value" : "Harrison"  
  }  
  ]  
}  

我需要找到组织为 "Org1"、活动为 true 且正则表达式与字段中的 'value' 相匹配的所有文档。

在mongoshell中完美运行。我试过查询:

db.collection.find({"organization" : "Org1", "active" : true, "fields" : {$elemMatch : {"key" : "key2","value" : {$regex : /iso/i}}}}).pretty()

但是当我试图将它转换成 Java 代码时 Spring,它给出了错误的结果。
1. 这个即使不符合模式也会给出文件:

@Query("{'organization' : ?0, 'active' : true, 'fields' : {$elemMatch : {'key' : ?1, 'value' : {$regex : ?2}}}}")
List<ObjectCollection> findFieldDataByRegexMatch(String org, String key, String pattern);  
  1. 尽管它应该提供任何文件,但这个文件没有提供。
        MongoTemplate MONGO_TEMPLATE = null;
        try {
            MONGO_TEMPLATE = multipleMongoConfig.secondaryMongoTemplate();
        } catch (Exception e) {
            e.printStackTrace();
        }

        List<Criteria> criteriaListAnd = new ArrayList<Criteria>();
        Criteria criteria = new Criteria();
        String pattern = "/iso/i";

        criteriaListAnd.add(Criteria.where("organization").is("Org1"));
        criteriaListAnd.add(Criteria.where("active").is(true));
        criteriaListAnd.add(Criteria.where("fields").elemMatch(Criteria.where("key").is(key).and("value").regex(pattern)));
        criteria.andOperator(criteriaListAnd.toArray(new Criteria[criteriaListAnd.size()]));

        Query query = new Query();
        query.addCriteria(criteria);

        List<ObjectCollection> objects = MONGO_TEMPLATE.find(query, ObjectCollection.class);

我在这里遗漏了什么以及我应该如何形成查询?

你犯了一个很小的错误,在你传递的模式中 / 是错误的,我花了半个小时才确定它,最后,在启用调试日志后我得到了它spring开机。

  1. 对于第一个查询,应该调用如下:

    springDataRepository.findFieldDataByRegexMatch("Org1", "key2", "iso")
    

    并且应在存储库中修改查询以处理大小写敏感性:

    @Query("{'organization' : ?0, 'active' : true, 'fields' : {$elemMatch : {'key' : ?1, 'value' : {$regex : ?2, $options: 'i'}}}}")
    List<Springdata> findFieldDataByRegexMatch(String org, String key, String pattern);
    
  2. 您的第二个查询也有同样的问题,只需将 String pattern = "/iso/i"; 更改为 String pattern = "iso"String pattern = "iso.*" ;

两者都将开始工作,有关详细信息,请查看我的 GitHub 存储库 https://github.com/krishnaiitd/learningJava/blob/master/spring-boot-sample-data-mongodb/src/main/java/sample/data/mongo/main/Application.java#L60

希望这能解决您的问题。