sql >> Database teknologi >  >> NoSQL >> MongoDB

Mongodb-forespørgsel:Seneste registrering efter dato for hver vare

Prøv med følgende uddrag

db.collection.aggregate([
            {$group: {
                    "_id": "$device_id",
                    "gateway_id": {"$last":"$gateway_id"},
                     data: {$last: '$data'},
                     date: {$last: '$date_time'},
                }},
            {$project: {
                     "device_id": "$_id",
                      "gateway_id": "$gateway_id",
                      "data": "$data",
                      "date_time": "$date"
                  }},
            {$sort: {
                    'date': -1
                }}
        ])

I ovenstående forespørgselsgruppe efter enheds-id og dato vil data og gateway_id være senest i hver række.

Output er-

{
    "result" : [ 
        {
            "_id" : 29,
            "gateway_id" : 1,
            "data" : [ 
                {
                    "r" : 203,
                    "v" : 3002
                }, 
                {
                    "r" : 221,
                    "v" : 3006
                }
            ],
            "device_id" : 29,
            "date_time" : "a"
        }, 
        {
            "_id" : 28,
            "gateway_id" : 1,
            "data" : [ 
                {
                    "r" : 203,
                    "v" : 3002
                }, 
                {
                    "r" : 221,
                    "v" : 3006
                }
            ],
            "device_id" : 28,
            "date_time" : "b"
        }, 
        {
            "_id" : 27,
            "gateway_id" : 1,
            "data" : [ 
                {
                    "r" : 203,
                    "v" : 3642
                }, 
                {
                    "r" : 221,
                    "v" : 3666
                }
            ],
            "device_id" : 27,
            "date_time" : "a"
        }
    ],
    "ok" : 1
}

Tak



  1. Meteor Up-implementering, kan ikke bruge meteor mongo --url

  2. MongoDB Node.js native driver sluger lydløst `bulkWrite` undtagelse

  3. Hvis mongodb aggregate ikke bruger indekser til $lookup, hvorfor øges min ydeevne, når jeg bruger indekser?

  4. afinstaller mongodb php-driver og installer en anden version