javascript - mongoose聯合查詢populate怎么用的?
問題描述
// 創建一個人物數據結構let personSchema = mongoose.Schema({_id:Number,name:String,post:[{ type:Number, ref:’postModel’}]});console.log(mongoose.Schema.ObjectId);// 根據結構生成人物模型let personModel = mongoose.model(’person’,personSchema);let ObjectId = mongoose.Types.ObjectId;// 創建一個文章數據結構let postSchema = mongoose.Schema({_id:Number,title:String,author:{ type:Number, ref:’personModel’},content:String});// 創建文章模型let postModel = mongoose.model(’post’,postSchema);開始查詢
postModel.find({}) .populate(’people’) .exec((err,data)=>{console.log(data) });
這是什么原因呢?換過用ObjectId查詢,也是一樣的結果,mongoose版本4.10.6,node版本8.1.0
問題解答
回答1:post:[{ type:Schema.ObjectId, ref:’postModel’}]
另外要注意ref的字段要和你注冊的model的名稱一致, 否則populate操作不會成功參考這個https://github.com/YueminHu/l...建議去學習下MDN的圖書館例子
相關文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. 哭遼 求大佬解答 控制器的join方法怎么轉模型方法5. mysql - 表名稱前綴到底有啥用?6. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?7. 編輯成功不顯示彈窗8. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。9. mysql - 數據庫表中,兩個表互為外鍵參考如何解決10. sql語句 - 如何在mysql中批量添加用戶?
