gpt4 book ai didi

mongodb - 对聚合结果中的子数组进行排序

转载 作者:IT老高 更新时间:2023-10-28 12:30:33 24 4
gpt4 key购买 nike

我有三个文件:

{
"id_user": "t57092501745ad6285ac58c22",
"name": "Day #1",
"date": {
"$date": "2016-04-21T20:50:00.190Z"
},
"text": "My text"
}

{
"id_user": "t57092501745ad6285ac58c22",
"name": "Day #2",
"date": {
"$date": "2016-04-22T20:50:00.190Z"
},
"text": "My text"
}

{
"id_user": "t57092501745ad6285ac58c22",
"name": "Day #3",
"date": {
"$date": "2016-04-22T20:51:00.190Z"
},
"text": "My text"
}

我需要将这些分组一天,所以我这样做:

{
"$match": {
"id_user": "t57092501745ad6285ac58c22"
}
}, {
"$sort": {
"date": -1
}
}, {
"$group": {
"_id": {
$dayOfYear: "$date"
},
"data": {
"$push": {
"id_user": "$id_user",
"name": "$name",
"date": "$date",
"text": "$text"
},
},
}

}

结果是:

{
{
_id: 113,
data: [{
"id_user": "t57092501745ad6285ac58c22",
name: "Day #1",
date: "2016-04-22T20:51:00.190Z",
text: "My text"
}]
}, {
_id: 114,
data: [{
"id_user": "t57092501745ad6285ac58c22",
name: "Day #3",
date: "2016-04-23T20:51:00.190Z",
text: "My text"
}, {
"id_user": "t57092501745ad6285ac58c22",
name: "Day #2",
date: "2016-04-23T20:50:00.190Z",
text: "My text"
}]
}
}

没关系,但顺序不是我需要的:

{ Day #1 }, { Day #3, Day #2 }

如果我将 sort 更改为 { "date": 1 } 我可以颠倒 2 组的顺序,这样:

{ Day #3, Day #2 }, { Day #1 }

但我不知道如何更改子数组内的顺序以获得正确的:

{ Day #1 }, { Day #2, Day #3 }

正确的方法是什么?

最佳答案

如果您希望“数组”中的项目按“升序”顺序排列,那么您的 $sort 顺序是错误的,您需要将其反转。 $group 作为“文档”的输出也没有以任何方式排序。因此,如果您想要一个特定的订单,那么您实际上还需要在返回的 _id 上执行 $sort:

[
{ "$match": {
"id_user": "t57092501745ad6285ac58c22"
}},
{ "$sort": { "date": 1 } }
{ "$group": {
"_id": { "$dayOfYear": "$date" },
"data": {
"$push": {
"id_user": "$id_user",
"name": "$name",
"date": "$date",
"text": "$text"
}
}
}},
{ "$sort": { "_id": 1 } }
]

那么两个命令都是正确的

关于mongodb - 对聚合结果中的子数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36817642/

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