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

få den relevante information mod objektværdien i MongoDB

  • $arrayElemAt for at hente det første element fra dic matrix
  • $objectToArray konverter A objekt til array
  • $reduce at iterere løkken af ​​elementet over det konverterede array og kontrollere tilstanden hvis _id.A matcher med data A returner derefter specifikt felt,
  • gør den samme proces for B og C
db.collection.aggregate([
  {
    $addFields: {
      dic: { $arrayElemAt: ["$dic", 0] }
    }
  },
  {
    $project: {
      _id: 1,
      dic: {
        A: {
          $reduce: {
            input: { $objectToArray: "$dic.data.A" },
            initialValue: "Not Found",
            in: {
              $cond: [
                { $eq: ["$$this.k", "$_id.A"] },
                "$$this.v.name",
                "$$value"
              ]
            }
          }
        },
        B: {
          $reduce: {
            input: { $objectToArray: "$dic.data.B" },
            initialValue: "Not Found",
            in: {
              $cond: [
                { $eq: ["$$this.k", "$_id.B"] },
                "$$this.v.description",
                "$$value"
              ]
            }
          }
        },
        C: {
          $reduce: {
            input: { $objectToArray: "$dic.data.C" },
            initialValue: "Not Found",
            in: {
              $cond: [
                { $eq: ["$$this.k", "$_id.C"] },
                "$$this.v.description",
                "$$value"
              ]
            }
          }
        }
      }
    }
  }
])

Legeplads




  1. Mongoose:Læs på ReplicaSet

  2. Hvad er hurtigere:`find().limit(1)` eller `findOne()` i MongoDB/Mongoose?

  3. Hent gemt billede fra mongodb ved hjælp af python

  4. Fejl ved hentning af MongoDB af _Id i Flask