sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB - Få senaste icke-nullfältsvärde från dokument med tidsstämpel

Du kan prova detta:

db.getCollection('test').aggregate([
    //Sort
    {$sort: { datetime: -1 }},
    //Add fields to an array
    {$group: {
        "_id": null,
        "field1": { $push: "$field1" },
        "field2": { $push: "$field2" },
    }},

    //Filter and do not include null values
    {$project: {
        "field1notNull" : {
              $filter: {
               input: "$field1",
               as: "f",
               cond: { $ne: [ "$$f", null ] }
            }
          },
        "field2notNull" : {
              $filter: {
               input: "$field2",
               as: "f",
               cond: { $ne: [ "$$f", null ] }
            }
          }
        }
    },
    //Get the first values of each
    {$project: {
        "_id": null,
        "field1": {$arrayElemAt: ["$field1notNull", 0]},
        "field2": {$arrayElemAt: ["$field2notNull", 0]} 
    }}
])


  1. Lägg till enkel lässkrivanvändare i mongo 3.4.1

  2. Tar bort objekt med ObjectId från array i Mongoose/MongoDB

  3. DB-ref i mongoose utan Schema.ObjectId?

  4. Hur kan jag sortera och begränsa med Mongoose