我有一个文件如下所示的集合。我想获得“_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查询中完成。
有解决方法吗?
谢谢。
答案 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"
}
})