对于数据模式,
var childSchema = new Schema({ name: 'string' });
var parentSchema = new Schema({
children: [childSchema]
});
var Parent = mongoose.model('Parent', parentSchema);
var Child = mongoose.model('Child', childSchema);
如果我们将父级保存为以下代码
var parent = new Parent;
var child = new Child({ name: 'Aaron' });
child.save(function(err) {
if (err)
console.log(err);
else
console.log('save child successfully');
});
parent.children.push(child);
parent.save(function(err) {
if (err)
console.log(err);
else
console.log('save parent successfully');
});
结果,集合的文档
> db.parents.find()
{ "_id" : ObjectId("56e3bf61f3dcb32104b3ea78"), "children" : [ { "_id" : ObjectId("56e3bf61f3dcb32104b3ea79"), "name" : "Aaron" } ], "__v" : 0 }
> db.children.find()
{ "_id" : ObjectId("56e3bf61f3dcb32104b3ea79"), "name" : "Aaron", "__v" : 0 }
我们知道_id
子文档也一样,保存在parents
集合中,我们可以通过这种方式获取子文档
Child.findById( req.params.childId , function(err, child) {
但是,如果我们以另一种方式保存parents
和children
记录,
var parent = new Parent({ children: [{ name: 'Matt' }, { name: 'Sarah' }] });
parent.save(function(err) {
if (err)
console.log(err);
else
console.log('save parent successfully');
});
结果是
> db.parents.find()
{ "_id" : ObjectId("56e3c1173832cb24043378d6"), "children" : [ { "name" : "Matt", "_id" : ObjectId("56e3c1173832cb24043378d8") }, { "name" : "Sarah", "_id" : ObjectId("56e3c1173832cb24043378d7") } ], "__v" : 0 }
> db.children.find()
children
集合中没有保存子文档,因此我们无法找到子文档
Child.findById( req.params.childId , function(err, child) {
仅通过以下方式访问子文档
Parent.findById( req.params.moduleId , function(err, mod) {
if(err) next(err);
res.json( mod.mod_roles.id( req.params.roleId );
});