我是否应该将子文档存储在单独的集合中

时间:2013-02-04 21:12:59

标签: mongodb mongoose normalization nosql

我构建了一些mangoose模式,它们的父子结构并不太复杂。当我创建我的父母时,我包含一个与子模式匹配的jsons数组,并且子文档被创建为ok但不会出现在mongodb中的单独子集合中。

但是,如果我后来添加了一些孩子,那么它们会出现在mongodb中的单独子集合中,父节点中有重复/引用(我使用Model.create创建它们,因为我需要访问它们的ObjectId)< / p>

由于我是NoSQL的新手,我不确定是否仍应该尝试保留单独的子文档集合。只让我的一些孩子出现在单独的收藏中是否有任何负面影响?

最小样本代码

var mongoose = require('mongoose'),
    arrangementSchema = mongoose.Schema({
        abc: String
    }),
    tuneSchema = mongoose.Schema({
        name: String,
        arrangements: [arrangementSchema]
    });

mongoose.connect('mongodb://localhost/jnr_dev');


var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function callback () {

});

var Arrangement = mongoose.model('Arr', arrangementSchema),
    Tune = mongoose.model('Tu', tuneSchema);


var tune = Tune.create({
    name: 'test'
}, function (err, newTune) {
    newTune.arrangements = [{abc:'abc1'}];
    newTune.save(function () {
        Arrangement.create({
            abc: 'abc2'
        }, function (err, arr) {
            newTune.arrangements.push(arr);
            newTune.save();
        });
    })
});

// and same behaviour with

var tune = Tune.create({
    name: 'test',
    arrangements: [{abc:'abc3'}]
}, function (err, newTune) {
    Arrangement.create({
        abc: 'abc4'
    }, function (err, arr) {
        newTune.arrangements.push(arr);
        newTune.save();
    });
});

Tus收集的结果

 {    "__v": NumberInt(2),    "_id": ObjectId("511037ef60e5af0000000002"),    "arrangements": {
     "0": {
       "abc": "abc1",
       "_id": ObjectId("511037ef60e5af0000000003")
    },
     "1": {
       "_id": ObjectId("511037ef60e5af0000000004"),
       "abc": "abc2"
    }   },    "name": "test" }

Arrs集合中的结果

 {
   "abc": "abc2",
   "_id": ObjectId("511037ef60e5af0000000004"),
   "__v": NumberInt(0)
}   

1 个答案:

答案 0 :(得分:0)

这是在第二个集合中创建文档的Arrangement.create()调用。我假设你只想要Tune集合中的一个子文档数组。参见:

http://mongoosejs.com/docs/subdocs.html

你应该这样做:

newTune.arrangements.push({
    abc: 'abc4'
});

newTune.save();