gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 09:20:15 24 4
gpt4 key购买 nike

我有一个集合,其中的文档如下所示。我想获取每个组中按“名称”分组的最大修订版的“_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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com