[轉] mongoose的populate


MongoDB是文檔型數據庫,所以它沒有關系型數據庫joins 特性。但是mongoose也有自己的方法來解決兩個表之間的關聯問題,Mongoose就是通過populate來解決這個問題的。接下來分享一下populate的方法。

populate的用法一

  • 創建兩個model

var personSchema = Schema({ _id : Number, name : String, age : Number, }); var storySchema = Schema({ _creator : { type: Number, ref: 'Person' }, title : String, }); var Story = mongoose.model('Story', storySchema); var Person = mongoose.model('Person', personSchema);
  • 創建數據

 var aaron = new Person({ _id: 0, name: 'Aaron', age: 100 }); aaron.save(function (err) { if (err) return ; var story1 = new Story({ title: "Once upon a timex.", _creator: aaron._id }); story1.save(function (err) { if (err) return ; }); // });
  • populate的使用

 Story
 .findOne({ title: 'Once upon a timex.' }) .populate('_creator') .exec(function (err, story) { if (err) return handleError(err); console.log('The creator is %s', story._creator.name); // prints "The creator is Aaron" } }) 

populate的用法二

var articlesSchema = new mongoose.Schema({ title : {type:String,default:""}, content : {type:String,default:''}, reduce_content:{type:String}, time : {type:Date,default:Date.now}, like_count:{type:Number,default:0}, comments: [{ reply:{type:mongoose.Schema.Types.ObjectId,ref:'user'}, time:{type:Date,default:Date.now}, content:{type:String}, replyTo:{type:String,default:''}, like_count:{type:Number,default:0}, }], type:{type:String,default:""}, isPublish:{type:Boolean,default:true}, }); var articles=mongoose.model("articles",articlesSchema );

這里的數據庫設計是article下嵌套了數組comments 而commets下的reply和user表建立了連接。
如何使用populate呢?

 
db.articles.findOne({_id:id}).populate('comments.reply')即可


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM