sql >> Databáze >  >> NoSQL >> MongoDB

přidat podmínku k výsledku nejnovějších hodnot

Když operace zahrnuje vypnutí úplných dokumentů, vzpomeňte si na $group . Přidání tohoto do vašeho kanálu by vás mělo nasměrovat správným směrem.

(hřiště)

db.collection.aggregate([
  {
    "$group": {
      _id: "cars",
      "cars": {
        "$push": {
          "$cond": [
            {
              "$ne": [
                {
                  "$arrayElemAt": [
                    "$mostRecentValues",
                    0
                  ]
                },
                {
                  "$arrayElemAt": [
                    "$mostRecentValues",
                    1
                  ]
                }
              ]
            },
            "$$ROOT",
            "$$REMOVE"
          ]
        }
      }
    }
  },
  {
    $unwind: "$cars"
  }
])

Pokud máte v každém dokumentu pouze 3 pole, můžete přidat:

  {
    $project: {
      car_id: "$cars.car_id",
      mostRecentTime: "$cars.mostRecentTime",
      mostRecentValues: "$cars.MostRecentValues"
    }
  }



  1. Jak programově získat aktuální databázi, do které Mongoid zapisuje?

  2. Závažná chyba:Třída 'MongoDB\Driver\Manager' nebyla nalezena

  3. Uložení objektu Mongoose do dvou kolekcí

  4. Jak importovat formát souboru .bson na mongodb