$ sort对子数组文档有效

时间:2013-08-01 08:16:16

标签: mongodb mongo-java

我有一个有阵列类型的集合。我想根据子数组的字段进行排序,但是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"应该在升序时出现。

1 个答案:

答案 0 :(得分:2)

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

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