首页 > 解决方案 > 查询Mongo DB中带条件的子元素个数

问题描述

我是 Mongo DB 的新手,希望对以下查询任务有所帮助。

我有一组如下所示的文档:

{
    "field_1" : {
      "subfield_1" : {
        "subsubfield_1" : "true",
        "subsubfield_2" : "false",
        "subsubfield_3" : "true"
        },
      "subfield_2" : "sf2"
      },
    "field_2" : {
      "subfield_1" : {
        "subsubfield_1" : "true",
        "subsubfield_2" : "false"
        },
      "subfield_2" : "sf2"
      },
    "field_3" : {
      "subfield_1" : {
        "subsubfield_1" : "true",
        "subsubfield_2" : "false",
        "subsubfield_3" : "false"
        },
      "subfield_2" : "sf2"
      }
}

而且我正在尝试查询,以便我为集合中的每个元素(1)准确指定要返回的字段(在这种情况下subfield_1,和subfield_2,以及,(2)subfield_1仅返回元素的计数true。所以我想要输出看起来像:

{
  {
    "subfield_1" : 2,
    "subfield_2" : "sf2"
  },
  {
    "subfield_1" : 1,
    "subfield_2" : "sf2"
  },
  {
    "subfield_1" : 1,
    "subfield_2" : "sf2"
  }
}

我一直在尝试这段代码,但这只给了我subfield_1每个元素的条目数:

db.getCollection('myCollection').aggregate(
  {
  $match: {<some other condition>}
  },
  {
  $project: {
    subfield_2: 1, 
    subfield_1: {'$size': '$subfield_1'}
  }
  }
)

提前致谢!

标签: mongodbaggregation-framework

解决方案


您需要运行$objectToArray将嵌套结构转换为键和值数组,然后使用$unwind为每个子文档获取单独的文档。$objectToArray然后你可以运行另一个$filter来只获取true值:

db.collection.aggregate([
    {
        $project: {
            doc: { $objectToArray: "$$ROOT" }
        }
    },
    {
        $unwind: "$doc"
    },
    {
        $match: { $expr: { $ne: [ "$doc.k", "_id" ] } }
    },
    {
        $project: {
            _id: 0,
            subfield_1: { $size: { $filter: { input: { $objectToArray: "$doc.v.subfield_1" }, cond: { $eq: [ "$$this.v", "true" ] } } } },
            subfield_2: "$doc.v.subfield_2"
        }
    }
])

蒙戈游乐场


推荐阅读