3

配列の種類のフィールドを持つコレクションがあります。サブ配列のフィールドに基づいてソートしたいのですが、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"の場合は、最初に来る必要があります。

4

1 に答える 1