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

标签 mongodb

我有一个集合,其中的文档如下所示。我想获取每个组中按“名称”分组的最大修订版的“_id”或整个文档。

{
    "_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 查询中进行。

有解决办法吗?

谢谢。

最佳答案

尝试以下聚合管道,它首先按修订字段降序对文档进行排序,然后是 $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
}

关于MongoDB - 通过查询获取组中最大值的ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31489254/

相关文章:

node.js - Node JS 适合作为即时通讯服务吗? MongoDB 适合做数据库吗?

mongodb - 高级Elasticsearch查询

mongodb - Mongoose 如何在幕后工作

mongodb - 蒙戈 : select only one field from the nested object

ruby-on-rails - 如何从父模型类调用 before_save 方法?

mongodb - 一般 MongoDB 性能故障排除

node.js - 从图表路由到 bar1 页面时出现 404 错误

javascript - 如何在jquery脚本中调用Node.js服务?

node.js - $inc 忽略 Mongoose

node.js - 使用 RoboMongo 生成新的 ObjectId