Mongo 数据库 - nested/embedded 文档键的计数

Mongo DB - Count of nested/embedded document keys

我正在尝试查找集合中跨文档的嵌入式文档键的计数。例如:

doc1 = {
  field1: 'foo',
  field2: {
    12322 = {
      ...
    },
    244 = {
      ...
    },
    8791 = {
      ...
    }
  }
}

doc2 = {
  field1: 'bar',
  field2: {
    789 = {
      ...
    },
    244 = {
      ...
    },
    8791 = {
      ...
    },
    12 = {
      ...
    }
  }
}

我想要 运行 一个聚合,我可以在其中获取这些键的计数。

结果

{
  12: 1,
  244: 2.
  789: 1,
  8791: 2,
  12322: 1
}

奖励:每个嵌入式文档中的一个字段是日期字段,我最终需要过滤掉早于特定日期的对象。

您可以使用聚合

  • $objectToArray 使对象成为键值对数组
  • $unwind解构数组
  • $group 统计每个键的总和,下一组重新排列键值对 $arrayToObjet
  • $replaceRoot 使它成为 root

这是代码

db.collection.aggregate([
  { $project: { data: { "$objectToArray": "$field2" } }},
  { "$unwind": "$data" },
  {
    "$group": {
      "_id": "$data.k",
      "count": { "$sum": 1 }
    }
  },
  {
    "$group": {
      "_id": null,
      "data": { "$push": { k: "$_id", v: "$count" } }
    }
  },
  {  $project: { data: { "$arrayToObject": "$data" } } },
  { "$replaceRoot": { "newRoot": "$data" } }
])

工作Mongo playground