mongodb - 具有多个字段的 Spring Data MongoDB 推送操作不起作用

标签 mongodb spring-boot aggregation

我在 MongoDB 中有一组数据对象-

[
    { "status" : "passed", "version" : "124" , "value" : 6 },
    { "status" : "passed", "version" : "123" , "value" : 10 },
    { "status" : "failed", "version" : "123" , "value" : 16 }
]

我想以这样的格式获取它-

[
    { 
    version: 124,
    "series" :[ 
        { 
            "name" : "passed", 
            "value" : 6 
        }
      ]
    },
    {
    version: 123,
    "series" : [
         { 
             "name" : "passed", 
             "value" : 10 
         },
         { 
             "name" : "failed", 
             "value" : 16 
         }
      ]
    }
]

我应该如何编写查询? 我写了这样的查询

我写了一个这样的查询:

Aggregation.group("version").push(new BasicDBObject("name","$status").append("value", "$value")).as("series");

使用上面的聚合查询,我得到这样的结果:

[
    { 
    version: 124,
    "series" :[ 
        { 
          "name" : null, 
          "value" : 6 
        }
      ]
    },
    {
    version: 123,
    "series" : [
         { 
           "name" : null, 
           "value" : 10
         },
         { 
           "name" : null, 
           "value" : 16 
         }
      ]
    }
]

好像没有在object中取status的值。我该如何解决这个问题?

最佳答案

我的查询是这样的:

db.results.aggregate([{
     {
       "$group": {
             "_id": {
                  "status": "$status",
                  "version": "$version",
              },
             "count": {
                  "$sum": 1
              }
            }
        }, {
            $group: {
                _id: "$_id.version",
                "series": {
                    $push: {
                        "status": "$_id.status",
                        "value": "$count"
                    }
                }
            }
        }
    ]);

所以我必须将聚合查询添加为:

Aggregation.group("version").push(new BasicDBObject("_id", "$_id.status").append("value", "$value")).as("series");

关于mongodb - 具有多个字段的 Spring Data MongoDB 推送操作不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55223506/

相关文章:

javascript - 来自子文档的 Mongodb 聚合/投影

java - 使用 Java 更新 mongodb 中的列表字段

Spring boot starter parent 2.0.0 未找到依赖项

java - 自从迁移到 Spring Boot 2 以来,注释上的修饰符出现了错误

java - 如何在Spring boot中加载没有任何文件扩展名的配置文件

r - 数据表 - 在几列上应用相同的函数来创建新的数据表列

用于将一个表的行聚合到另一个表的 MySQL 触发器

mongodb - mongo3.0 恢复失败,错误为 Failed : restore error: insertion error: EOF

mongodb - 如何在我的应用程序中显示 jupyter notebook 或 apache zeppelin?