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

Restituzione asimmetrica dei dati MongoDB, il primo elemento dell'array restituito per intero, il resto con determinate proprietà omesse?

Se la tua matrice di documenti secondari che vuoi omettere non è molto grande. Lo rimuoverei solo dal lato dell'applicazione. Eseguire l'elaborazione in MongoDB significa scegliere di utilizzare le risorse di calcolo di MongoDB invece della tua applicazione. In genere l'applicazione è più facile ed economica da scalare, quindi è preferibile l'implementazione a livello di applicazione.

Ma in questo caso esatto non è troppo complesso implementarlo in MongoDB:

db.collection.aggregate([
  {
    $addFields: { // keep the first element somewhere
      first: { $arrayElemAt: [ "$mainArray", 0] }
    }
  },
  {
    $project: { // remove the subdocument field
      "mainArray.array": false
    }
  },
  {
    $addFields: { // join the first element with the rest of the transformed array
      mainArray: {
        $concatArrays: [
          [ // first element
            "$first"
          ],
          { // select elements from the transformed array except the first
            $slice: ["$mainArray", 1, { $size: "$mainArray" }]
          }
        ]
      }
    }
  },
  {
    $project: { // remove the temporary first elemnt
      "first": false
    }
  }
])

MongoDB Parco giochi