如何在MongoDB中对此数据进行排序?

时间:2014-05-25 06:56:03

标签: node.js mongodb mongoose aggregation-framework

/* 0 */
{
  "_id" : ObjectId("5380c9e097632cee5b000007"),
  "month" : "5",
  "userid" : "53806aac12c75f4b51000001",
  "__v" : 7,
  "posts" : [{
      "postid" : ObjectId("538185cae0c6b8666e000008"),
      "ts" : ISODate("2014-05-25T05:55:22.976Z"),
      "userid" : "53806aac12c75f4b51000001",
      "name" : "BBB",
      "text" : "b1",
    }]
}

/* 1 */
{
  "_id" : ObjectId("5380c80e97632cee5b000001"),
  "month" : "5",
  "userid" : "5380629ea3b31f864f000001",
  "__v" : 24,
  "posts" : [{
      "postid" : ObjectId("538185b2e0c6b8666e000004"),
      "ts" : ISODate("2014-05-25T05:54:58.703Z"),
      "userid" : "5380629ea3b31f864f000001",
      "name" : "AAA",
      "text" : "a1",
    }, {
      "postid" : ObjectId("538185b7e0c6b8666e000006"),
      "ts" : ISODate("2014-05-25T05:55:03.474Z"),
      "userid" : "5380629ea3b31f864f000001",
      "name" : "AAA",
      "text" : "a2",

    }, {
      "postid" : ObjectId("538185d6e0c6b8666e00000a"),
      "ts" : ISODate("2014-05-25T05:55:34.231Z"),
      "userid" : "5380629ea3b31f864f000001",
      "name" : "AAA",
      "text" : "a3",
    }]
}

这是我的数据。

我想将此数据排序为'Ts'(数据)。

我想通过'posts.Ts'排序列表像这样..
名称:AAA,text = a3
名称:BBB,text = b1
名称:AAA,text = a2
名称:AAA,text = a1

但我不知道如何查询。请跟我说说

这是我在Node和mongoose中的代码。

db.collection('walls', function(err, collection) {

collection.find(function(err, data) {

collection.aggregate(
{$match: {userid:userid}},
{$project: {posts: 1,_id:0}},
{$sort:{'posts.ts':1}}, 
{$unwind: "$posts"}
)}

...

1 个答案:

答案 0 :(得分:0)

你是正确的原则,但你有错误的管道阶段。在排序之前,您需要$unwind数组:

db.collection.aggregate([
    { "$match": { "userId": userId" } },
    { "$project": { "_id": 0, "posts": 1 } },
    { "$unwind": "$posts" },
    { "$sort": { "posts.ts": 1, "posts.name": 1 } }
])