MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

MongoDB Показване на детски елементи във връзка Едно към много

Следният тръбопровод трябва да ви даде идеята

db.getCollection('yourCollection').aggregate(
    {
        $unwind: {
            path: "$dates",
            includeArrayIndex: "idx"
        }
    },
    {
        $project: {
            _id: 0,
            dates: 1,
            numbers: { $arrayElemAt: ["$numbers", "$idx"] },
            goals: { $arrayElemAt: ["$goals", "$idx"] },
            durations: { $arrayElemAt: ["$durations", "$idx"] }
        }
    }
)

който произвежда следния изход за вашата проба

/* 1 */
{
    "dates" : NumberLong(1399518702000),
    "numbers" : "5982",
    "goals" : "1",
    "durations" : "78"
}

/* 2 */
{
    "dates" : NumberLong(1399126333000),
    "numbers" : "5983",
    "goals" : "0",
    "durations" : "45"
}

/* 3 */
{
    "dates" : NumberLong(1399209192000),
    "numbers" : "5984",
    "goals" : "4",
    "durations" : "90"
}

/* 4 */
{
    "dates" : NumberLong(1399027545000),
    "numbers" : "5985",
    "goals" : "2",
    "durations" : "90"
}



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Избягвайте общото ограничение от 16MB

  2. Съвети за съхранение на резервни копия на MongoDB в облака

  3. Масивите, съхранявани в MongoDB, запазват ли реда си?

  4. Деинсталирайте mongoDB от ubuntu

  5. Съвпадение с подниз в агрегирането на mongodb