sql >> Databáze >  >> NoSQL >> MongoDB

Mongoose - Jak seskupit podle a naplnit?

Příklad pomocí $lookup populate, lookup naplní jako pole, proto $unwind.

Message.aggregate(
    [
        { "$match": { "to": user } },
        { "$sort": { "date": 1 } },
        { "$group": { 
            "_id": "from",
            "to": { "$first": "$to" },
            "message": { "$first": "$message" },
            "date": { "$first": "$date" },
            "origId": { "$first": "$_id" }
        }},
        { "$lookup": {
             "from": "users",
             "localField": "from",
             "foreignField": "_id",
             "as": "from"
        }},
        { "$lookup": {
             "from": "users",
             "localField": "to",
             "foreignField": "_id",
             "as": "to"
        }},
        { "$unwind": { "path" : "$from" } },
        { "$unwind": { "path" : "$to" } }
    ],
    function(err,results) {
        if (err) throw err;
        return results;
    }
)


  1. Přehled správy uživatelů MongoDB

  2. MongoDB s Mongoidem v Rails - Geoprostorové indexování

  3. PHP nemůže najít ovladač MongoDB

  4. phpredis na fedoře 12