gpt4 book ai didi

mongodb - 对子数组文档执行 $sort

转载 作者:可可西里 更新时间:2023-11-01 10:33:06 26 4
gpt4 key购买 nike

我有一个集合,它有一个数组类型的字段。我想根据子数组的字段进行排序,但 Mongo 没有对数据进行排序。

我的收藏是:

{
"_id" : ObjectId("51f1fcc08188d3117c6da351"),
"cust_id" : "abc123",
"ord_date" : ISODate("2012-10-03T18:30:00Z"),
"status" : "A",
"price" : 25,
"items" : [{
"sku" : "ggg",
"qty" : 7,
"price" : 2.5
}, {
"sku" : "ppp",
"qty" : 5,
"price" : 2.5
}]
}

我的查询是:

db.orders.aggregate([
{ "$unwind" : "$items"} ,
{ "$match" : { }} ,
{ "$group" : { "items" : { "$addToSet" : { "sku" : "$items.sku"}} , "_id" : { }}} ,
{ "$sort" : { "items.sku" : 1}} ,
{ "$project" : { "_id" : 0 , "items" : 1}}
])

结果是:

    "result" : [
{
"items" : [
{
"sku" : "ppp"
},
{
"sku" : "ggg"
}
]
}
],
"ok" : 1

"sku":"ggg" 在升序时应该排在第一位。

最佳答案

您想在重新组合之前进行排序:

db.orders.aggregate([ 
{ "$unwind" : "$items"} ,
{ "$sort" : { "items.sku" : 1}},
{ "$match" : { }} ,
{ "$group" : { "items" : { "$push" : { "sku" : "$items.sku"}} , "_id" : null}} ,
{ "$project" : { "_id" : 0 , "items" : 1}}
])

关于mongodb - 对子数组文档执行 $sort,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17988585/

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