sql >> Databasteknik >  >> NoSQL >> MongoDB

få relevant information mot objektvärdet i MongoDB

  • $arrayElemAt för att hämta det första elementet från dic array
  • $objectToArray konvertera A objekt till array
  • $reduce att iterera slingan av element ovanför den konverterade arrayen och kontrollera villkoret om _id.A matchar med data A returnera sedan specifikt fält,
  • gör samma process för B och 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"
              ]
            }
          }
        }
      }
    }
  }
])

Lekplats




  1. Hur kör man en Redis-server OCH en annan applikation i Docker?

  2. Lagring av DateTime i MongoDB påverkar prestanda

  3. Se mer än 20 senaste dokumenten i MongoDB Compass från Schema

  4. grails mongodb anslutning vägrade