子ID,在parentSchema范围内唯一,或在所有子项中?

时间:2016-03-12 06:07:41

标签: mongoose mongoose-schema

我不知道如何在文档中找到答案,这就是为什么我要打扰你的问题。
我有两个使用mongoose的模式:

childSchmea
    name: String


parentSchema
    name: String,
    childrens: [childSchema]

我也有ChildParent型号 现在,在我看到的其他最佳实践中,如果我们想要一个特殊父项的一个特殊的子项,我们使用这个网址:

/parents/:parentId/children/:childId

现在每个child都有自己的id由mongoose制作。 但它对另一个父母的孩子来说是独一无二的吗?

为了让孩子,我应该这样做:

Parent.findById( req.params.moduleId , function(err, mod) {
    if(err) next(err);
    res.json( mod.mod_roles.id( req.params.roleId );
});

我的意思是childSchema 嵌入,而且它不是参考所以:

  • 我有一个儿童模特。
  • 我的孩子模型不是独立的,它取决于父模型。但它的身份也是依赖吗? 当然,用此代码替换findById部分:

我的问题是,为了让孩子可以使用此代码:

Child.findById( req.params.childId , function(err, child) {
     // send the child
});

这给出了相同的结果吧?或者我错了,孩子的id只在其父母范围内是唯一的?

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:1)

对于数据模式,

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) {

但是,如果我们以其他方式保存parentschildren个文档,

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 );
});