sql >> Database >  >> NoSQL >> MongoDB

verkrijg de relevante informatie tegen de objectwaarde in MongoDB

  • $arrayElemAt om het eerste element van dic te krijgen reeks
  • $objectToArray converteer A object naar array
  • $reduce om de lus van het element boven de geconverteerde array te herhalen en de voorwaarde te controleren als _id.A komt overeen met gegevens A retourneer vervolgens een specifiek veld,
  • doe hetzelfde proces voor B en 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"
              ]
            }
          }
        }
      }
    }
  }
])

Speeltuin




  1. Hoe kan ik subdocumenten uit een array halen?

  2. Begrijpen vinden in Node/Mongo

  3. MongoDB Node gevonden hoe om te gaan met geen resultaten?

  4. Hoe verschilt kolomgeoriënteerd NoSQL van documentgeoriënteerd?