用mongoose查找后如何更改子文档

时间:2013-09-06 08:49:25

标签: javascript node.js mongodb mongoose

我使用mongoose有类似下面的代码。

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

mongoose.connect('mongodb://localhost/hoge');
var UserSchema = new Schema({
  name: String,
  children: [ChildSchema],
});
var ChildSchema = new Schema({
  name: String,
}, {_id: false});

var User = mongoose.model('User', UserSchema);
var Child = mongoose.model('Child', ChildSchema);

User.findOne({_id: '52299322fdbbdec515000001'}, function(err, user) {
  console.log(user);
  for (var i=0; i<user.children.length; i++) {
    var child = user.children[i];
    child.name = 'newchild';
  }
  user.save(function(err) {
    console.log(user);
    mongoose.disconnect();
  });
});

这是我在mongodb的记录。

{
  "name" : "u1",
  "_id" : ObjectId("52299322fdbbdec515000001"),
  "children" : [ { "name" : "c2" } ],
  "__v" : 0
}

当我运行脚本时,它会在下面输出。

{ name: 'u1',
  _id: 52299322fdbbdec515000001,
  __v: 0,
  children: [ { name: 'c2' } ] }

{ name: 'u1',
  _id: 52299322fdbbdec515000001,
  __v: 0,
  children: [ { name: 'newchild' } ] }

但是我在mongodb的记录没有改变。为什么呢?

仅供参考,如果我在保存之前插入此代码,记录会更改。

user.children.push({name: 'somechild'});

1 个答案:

答案 0 :(得分:0)

对不起,我已经解决了。

问题是声明架构的顺序。

如果我尝试了这种改变,那就有用了。

/* first, children's schema */
var ChildSchema = new Schema({
  name: String,
}, {_id: false});

/* seconds, parent's schema */
var UserSchema = new Schema({
  name: String,
  children: [ChildSchema],
});