4

我正在使用 MongoTemplate 构建一个查询以从 mongo 集合中检索元素。查询条件包含一个带有下划线的属性,它以某种方式被替换为“._”,使查询始终返回 0 个元素。

Criteria matchingCriteria = Criteria
.where("entries").elemMatch(Criteria.where("app_id").is(appId))

查看日志,我可以看到生成的查询如下:

o.s.data.mongodb.core.MongoTemplate: find using query: { "entries" : { "$elemMatch" : { "app._id" : "5834718ab0"}}} fields: null for class: Ranking in collection: ranking

我已经尝试过使用 BasicQuery,用 '\\' 斜线下划线,并使用 unicode“app\u005Fid”。它们都不起作用。重要的是要注意我的数据库中存在一个名为“app”的集合。

行为看起来不标准。当我使用另一个带下划线的属性时,该值不会被替换:

Criteria matchingCriteria = Criteria .where("entries").elemMatch(Criteria.where("unique_app_id").‌​is(appId)) 

日志:

o.s.data.mongodb.core.MongoTemplate find using query: { "entries" : { "$elemMatch" : { "unique_app_id" : "1131706359"}}} fields: null for class: class Ranking in collection: ranking

entries 是一个具有以下格式的集合的数组:

{
    "instanceId" : "654ba2d16579e",
    "app_id" : "583471adb0",
    "unique_app_id" : "554577506",
    "value" : 169
 }

值得一提的是,相同的查询(没有下划线替换)在 mongo IDE(本例中为 Robomongo)中运行良好。

我正在使用 spring-boot-starter-data-mongodb 1.4.1.RELEASE。

我现在真的没有想法。

有什么建议吗?

4

1 回答 1

4

根据此Spring Data Commons文档的第 3.4.3 节:

由于我们将下划线视为保留字符,因此我们强烈建议遵循标准的 Java 命名约定(即在属性名称中不要使用下划线,而是使用驼峰式命名)。

我不相信您可以使用 Spring 在元素名称中间使用下划线字符。手动引用以引用的集合命名。使用文档类型(单数的集合名称)后跟_id ( <document>_id ). 这是唯一可以在中间使用下划线的情况。

更新:这是您所看到的确切行为的现有拉取请求,以及 Spring 的错误跟踪器

在 Mongo shell 中,我可以成功执行以下查询:

> db.app.findOne({ "entries" : { "$elemMatch" : { "app_id" : "1"}}})
{
    "_id" : ObjectId("58a5bc6afa8dd4ae3097d5f7"),
    "name" : "Keith",
    "entries" : [
        {
            "instanceId" : "654ba2d16579e",
            "app_id" : "1"
        }
    ]
}

因此,也许 Spring API_在解析条件时找到多个令牌时不会拆分,但在解析一个时会拆分以进行遍历。

于 2017-02-16T11:14:01.333 回答