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')即可

myjeajea
17 声望0 粉丝