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