38

私はしばらく探していましたが、内部配列をソートして、現在作業しているドキュメントに保持できないようです。

{
    "service": {
        "apps": {
            "updates": [
              {
                "n" : 1
                "date": ISODate("2012-03-10T16:15:00Z")
              },
              {
                "n" : 2
                "date": ISODate("2012-01-10T16:15:00Z")
              },
              {
                "n" : 5
                "date": ISODate("2012-07-10T16:15:00Z")
              }
            ]
        }
     }
 }

そのため、サービスとして返されるアイテムを保持したいのですが、更新配列を並べ替えます。これまでのところ、私が持っているシェルでは:

db.servers.aggregate(
        {$unwind:'$service'},
        {$project:{'service.apps':1}},
        {$unwind:'$service.apps'}, 
        {$project: {'service.apps.updates':1}}, 
        {$sort:{'service.apps.updates.date':1}});

誰もがこれを助けることができると思いますか?

4

3 に答える 3

65

これを行うには$unwind、配列を ing し、updates結果のドキュメントを で並べ替えてから、並べ替えられた順序を使用してそれらを元に戻します。date$group_id

db.servers.aggregate(
    {$unwind: '$service.apps.updates'}, 
    {$sort: {'service.apps.updates.date': 1}}, 
    {$group: {_id: '$_id', 'updates': {$push: '$service.apps.updates'}}}, 
    {$project: {'service.apps.updates': '$updates'}})
于 2013-03-13T15:09:43.450 に答える