对数组 MongoDB 中的所有文档使用 $size

Use $size on all documents in array MongoDB

这是我的 collection 的结构部分:

_id: ObjectId("W"),
names: [
    {
        number: 1,
        list: ["A","B","C"]
    },
    {
        number: 2,
        list: ["B"]
    },
    {
        number: 3,
        list: ["A","C"]
    }
    ...
],
...

我使用这个请求:

db.publication.aggregate( [ { $match: { _id: ObjectId("54a1de90453d224e80f5fc60") } }, { $group: { _id: "$_id", SizeName: { $first: { $size: { $ifNull: [ "$names", [] ] } } }, names: { $first: "$names" } } } ] );

但我现在会在 names 数组的每个文档中使用 $size

是否可以得到这个结果(其中“sizeList”是$size的结果):

_id: ObjectId("W"),
SizeName: 3,
names: [
    {
        SizeList: 3,
        number: 1,
        list: ["A","B","C"]
    },
    {
        SizeList: 1,
        number: 2,
        list: ["B"]
    },
    {
        SizeList: 2,
        number: 3,
        list: ["A","C"]
    }
    ...
],
...

这不一定是最有效的方法,但我认为它可以实现您的目标:

db.publication.aggregate( [ 
    { $unwind: '$names' },
    { $unwind: '$names.list' },
    { $group: {
        _id: { _id: "$_id", number: "$names.number" },
        SizeList: { $sum: 1 },
        list: { $push: "$names.list" }
      }
    },
    { $group: {
        _id: "$_id._id",
        names: {
            $push: {
                number: "$_id.number",
                list: "$list",
                SizeList: "$SizeList"
            }
        },
        SizeName: {$sum: 1}
      }
    }
]);

你真正想要的只是一个$project stage and use $map来改变数组成员的内容:

db.names.aggregate([
    { "$project": {
        "SizeName": { "$size": "$names" },
        "names": { "$map": {
            "input": "$names",
            "as": "el",
            "in": {
                "SizeList": { "$size": "$$el.list" },
                "number": "$$el.number",
                "list": "$$el.list"
            }
        }}
    }}
])

您可以交替使用 $unwind 进行处理,然后将其重新分组,但是当您拥有 MongoDB 2.6 时,这有点冗长。