MongDB 聚合两个同名值

测试用户

我的代码中有以下聚合函数来计算在数据库中找到值的次数:

  let data: any = await this.dataModel.aggregate(
      [
        {
          $match: {
            field: new ObjectID(fieldID),
          },
        },
        {
          $group: {
            _id: "$value",
            total_for_value: { $sum: 1 },
          },
        },
      ]
    );

这可以正常工作,但是我的数据设置有点不同。我有两种类型的值字段。有些像这样:

    {
    "_id" : ObjectId("123"),
    "value" : "MALE"
    }

有些像这样:

{
    "_id" : ObjectId("456"),
    "value" : {
        "value" : "MALE",
    }
}

有没有办法对 _id 和 _id.value 相同的那些进行分组?目前,它分别计算它们。

吉布斯
db.collection.aggregate([
  {
    "$addFields": {
      "key2": {
        "$cond": {
          "if": {
            $and: [
              {
                "$eq": [
                  {
                    "$type": "$key"
                  },
                  "object"
                ]
              }
            ]
          },
          "then": "$key.value",
          "else": "$key"
        }
      }
    }
  },
  {
    "$group": {
      "_id": "$key2",
      "data": {
        $push: "$$ROOT"
      }
    }
  }
])

如果_id.value是一个对象,这将完成这项工作。

操场

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章