javascript - Mongoose - 如何分组和填充?

标签 javascript node.js mongodb mongoose aggregation-framework

我使用 MongoDB 和 Mongoose 作为我的 ODM,并尝试在同一语句中使用 populategroup by 进行查询。

这是我的简单文档模型:

var userSchema = new Schema({
    username: String
});

var messageSchema = new Schema({
    from: { type: Schema.ObjectId, ref: 'User' },
    to: { type: Schema.ObjectId, ref: 'User' },
    message: String,
    date: { type: Date, default: Date.now }
});

我只是想为一个用户获取每条消息,按他与之交谈的每个用户分组。我试过这样:

this.find({ 'to': user })
    .sort({ 'date': 1 })
    .group('from')
    .populate(['from', 'to'])
    .exec(callback);

但是,不幸的是,我的模型没有 group 方法。你有什么解决方案,让这个工作?

谢谢。

最佳答案

使用 $lookup 填充的示例,lookup 填充为数组,因此 $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;
    }
)

关于javascript - Mongoose - 如何分组和填充?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25231022/

相关文章:

javascript - 在返回 View 中传递 json 作为参数

javascript - 如何在asp上添加客户端事件:menu item click

javascript - DataTables - 按图像的替代字符串对列进行排序

node.js - Nodejs 中的 OTP 验证?

javascript - 如何调试node + mongo连接错误

c# - 如何在不使用属性的情况下指定用于 MongoDB 反序列化的构造函数 (C#)

javascript - 在 WordPress 自定义模板中使用 Jquery .click() 实现选项卡

node.js - 在nodejs(express)中将neo4j的创建约束语句放在哪里?

python - SocketIO 从 Node 服务器发送到 Python 客户端

c++ - 在 Mac OS 上安装 MongoDB C++ 驱动程序