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

Concat int og string array felter, som er i forskellige arrays

Du kan bruge nedenstå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. Hvorfor er der en understregning foran MongoDb dokument-id?

  2. Mongo:show dbs viser ikke test-db. Hvorfor?

  3. Optimale sammensatte indekser for $ eksisterer:sand (sparsomme indekser)

  4. Undtagelse for socket timeout i Mongo