MongoDB - 通过查询获取组中最大值的id

时间:2015-07-18 08:25:25

标签: mongodb

我有一个文件如下所示的集合。我想获得“_id”或每个组中按“name”分组的最大修订版本的整个文档。

{
    "_id" : ObjectId("55aa088a58f2a8f2bd2a3793"),
    "name" : "abc",
    "revision" : 1
}

{
    "_id" : ObjectId("55aa088a58f2a8f2bd2a3794"),
    "name" : "abc",
    "revision" : 2
}

{
    "_id" : ObjectId("55aa088a58f2a8f2bd2a3795"),
    "name" : "def",
    "revision" : 1
}

{
    "_id" : ObjectId("55aa088a58f2a8f2bd2a3796"),
    "name" : "def",
    "revision" : 2
}

在这种情况下,我只想选择第2和第4个文件。我尝试了各种方法,包括聚合框架,但不能完全在MongoDB查询中完成。

有解决方法吗?

谢谢。

2 个答案:

答案 0 :(得分:6)

尝试以下聚合管道,首先按修订字段降序对文档进行排序,然后通过名称字段对 $group 进行排序,添加另一个使用 $first 系统变量表达式上的> $$ROOT 运算符:

db.collection.aggregate([
    {
        "$sort": {
            "revision": -1
        }
    },
    {
        "$group": {
            "_id": "$name",
            "max_revision": {
                "$max": "$revision"
            },
            "doc": {
                "$first": "$$ROOT"
            }
        }
    }
])

<强>输出

/* 0 */
{
    "result" : [ 
        {
            "_id" : "def",
            "max_revision" : 2,
            "doc" : {
                "_id" : ObjectId("55aa088a58f2a8f2bd2a3796"),
                "name" : "def",
                "revision" : 2
            }
        }, 
        {
            "_id" : "abc",
            "max_revision" : 2,
            "doc" : {
                "_id" : ObjectId("55aa088a58f2a8f2bd2a3794"),
                "name" : "abc",
                "revision" : 2
            }
        }
    ],
    "ok" : 1
}

答案 1 :(得分:3)

您应该使用Mongo aggregation来获得预期的输出。

查询如下:

db.collection.aggregate({
    $group: {
    _id: "$name",
    "revision": {
        $max: "$revision"
    }
    }
}, {
    $project: {
    "name": "$_id",
    "revision": 1,
    "_id": 0
    }
})

修改

您可以使用以下查询 -

db.collection.aggregate({
    $sort: {
    revision: -1
    }
}, {
    $group: {
    _id: "$name",
    "revision": {
        "$max": "$revision"
    },
    "original": {
        $first: "$$ROOT"
    }
    }
}, {
    $project: {
    "name": "$_id",
    "revision": 1,
    "_id": "$original._id"
    }
})