javascript - mongoose聯合查詢populate如何使用?
迷茫
迷茫 2017-06-26 10:50:40
0
1
667

使用node練習部落格專案的時候,文章需要關聯使用者和分類,評論集合,所以就用到了mongoose的populate查詢,可是無法傳回想要的資料,程式碼如下:

儲存文章的:

    // 拿到session中的用户信息
    let authorObj = {author: ObjectId(req.session.userInfo.userID)};
    let cateObj = {category: ObjectId(req.body.category)};
    // 增加到数据中
    postData = Object.assign(req.body,authorObj,cateObj);
    // 添加新数据
    postModel.create(postData)
        .then((result)=>{
            if(!result){
                reMessage.msg='文章保存错误';
                reMessage.code=2003;
                res.send(reMessage);
                return;
            }
            reMessage.msg='文章发表成功';
            reMessage.code=0;
            res.send(reMessage);
        });

傳回資料的:

postModel.find({})
        .populate({path:'users',select:'username'})
        .then((data)=>{
            console.log(data);
            res.render('admin/posts-list',{
                login:req.session.login,
                userInfo:req.session.userInfo,
                fields:['标题','作者','分类','发表时间'],
                datas:data
            });
        });
        
        
        

具體程式碼就如上,為什麼不行?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回覆(1)
曾经蜡笔没有小新

已解決,是創建Schema的字段ref引用錯誤,應該引用userModel = db.model('user',suerSchema)的第一個參數,而不是userModel

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板