TypeError:更新文档时在非对象上调用Object.keys

时间:2014-03-07 15:06:49

标签: node.js mongodb mongoose

我正在尝试通过递增计数器并将对象推送到数组来更新现有文档。

以下是User的模式:

var UserSchema = new Schema({
  [...]
  posts: {
    totalWords: { type: Number, min: 0, default: 0 },
    _entries: [
      {
        words: { type: Number, min: 0 },
        body: { type: String },
        date: Date
      }
    ]
  },
});

这是更新代码:

var newPost = {
  words: req.body.words,
  body: req.body.entry,
  date: new Date()
};

User.findOne(req.user._id, function (err, user) {
  var previous = user.posts.totalWords;
  user.posts.totalWords = previous + newPost.words;
  user.posts._entries.push(newPost);

  user.save(function (err) {
    if (err) return res.send(400, err);
    return res.json(newPost);
  });
});

我收到以下错误:

[TypeError: Object.keys called on non-object]

关于如何解决这个问题的任何想法?

3 个答案:

答案 0 :(得分:2)

回答我自己的问题

我能够通过改变来解决问题:

User.findOne(req.user._id, function (err, user) { [...] });

进入这个:

User.findById(req.user._id, function (err, user) { [...] });

答案 1 :(得分:2)

我认为,如果你想使用findOne,你需要遵循以下语法:

User.findOne({'_ id':req.user._id},{},function(err,user){   ...   });

答案 2 :(得分:0)

不确定findById()findOne(),但我在使用格式错误的数据或与之对应的数据进行保存或更新的同时返回Object.keys called on non-object的Mongoose对象时出现问题旧架构。在初始化文档时,Mongoose期待某种子文档,但数据库中的数据并不匹配。

对我而言,当我将模式从简单对象(StringNumber等)更改为某种更复杂的子文档时,通常会发生这种情况。模式类型混合在一起,对象不会加载,甚至不能解决问题。我必须使用the native driver进入我的数据库,使用$type运算符搜索格式错误的文档,并单独更新它们。