sql >> Databasteknik >  >> NoSQL >> MongoDB

Concat int och string arrayfält som finns i olika arrayer

Du kan använda nedanstående aggregering

db.collection.aggregate([
  { "$project": {
    "itemQtyList": {
      "$reduce": {
        "input": { "$range": [0, { "$size": "$sale.soldItems" }] },
        "initialValue": "",
        "in": {
          "$concat": [
            "$$value",
            { "$cond": [{ "$eq": ["$$this", 0] }, "", " \n "] },
            { "$toString": {
              "$arrayElemAt": [
                "$sale.soldItems.qty",
                "$$this"
              ]
            }},
            " ",
            { "$arrayElemAt": ["$sale.items.unit", "$$this"] }
          ]
        }
      }
    }
  }}
])

MongoPlayground




  1. Hur man $skjuter ett fält beroende på ett tillstånd?

  2. Uppdatera inbäddat dokument i mongodb med C#

  3. Få tillgång till undersamling i mongoid med skenor för att redigera och skapa ny post

  4. Hur kör jag en förklara-fråga med 2.4 C# Mongo-drivrutinen?