7

我在这里摸不着头脑,就像通常的节点项目一样,我不确定我是否做错了什么或者我是否遇到了错误。

我有一个服务器模式,它可以有任意数量的嵌入式文档,称为服务。我遇到了一个问题,尽管我已经成功地从服务器对象中删除了单个服务,但当我告诉它保存它并没有从数据库中删除它时。保存功能正在工作,因为它保存了我所做的任何更改,并且还在推送新的嵌入式文档,它只是没有删除已经存在的文档。

这是我的代码的一个相对简化的示例:

app.put('/server/:id', function(req, res, next){
  app.Server.findOne({_id: req.params.id}, function(err, server) {
    server.updated = new Date();
    ...

    for (var num = _.size(req.body.server.services) - 1; num >= 0; num--){
      // Is this a new service or an existing one
      if (server.services[num]) {
        // Is it marked for deletion? If so, delete it
        if (req.body.server.services[num].delete == "true") {
          server.services[num].remove()
        } else { // else, update it
          server.services[num].type = req.body.server.services[num].type
          ...
        }
      } else {
        // It's new, add it
        delete req.body.server.services[num]["delete"]
        server.services.push(req.body.server.services[num]);
      }
    }

    server.save(function(err){
      if (!err) {
        req.flash('success', 'Server updated')
      } else {
        req.flash('error', 'Err, Something broke when we tried to save your server. Sorry!')
        console.log(err)
      }
      res.redirect('/')
    });
  })
});

所以 remove() 实际上是在删除服务。如果我在保存之前执行 server.toObject() ,则它不存在。任何想法为什么它不会在保存时将其从数据库中删除?

编辑:我想版本号会有所帮助。node@0.4.2, mongoose@1.1.5 express@2.0.0rc

4

2 回答 2

5

我可能是错的,因为我没有测试你的例子,但这听起来像猫鼬没有检测到嵌入式文档被修改。

架构类型文档页面

由于它是无模式类型,因此您可以将值更改为您喜欢的任何其他值,但Mongoose 失去了自动检测/保存这些更改的能力。要“告诉”Mongoose Mixed 类型的值已更改,请调用文档的 .markModified(path)方法,将路径传递给刚刚更改的 Mixed 类型。

person.anything = { x: [3, 4, { y: "changed" }] };
person.markModified('anything');
person.save(); // anything will now get saved

所以你的回答可能就像使用 markModified() 函数一样简单。

于 2011-10-24T23:00:34.323 回答
3

我找到了一种临时解决此问题的方法。

我所做的是将嵌入的文档加载到一个数组中,拼接要删除的文件并替换该数组。像这样的东西:

var oldusers = dl.users;
oldusers.splice(dl.users.indexOf(req.currentUser.id), 1);
dl.users = oldusers;
dl.save(function(err) {...

我知道这取决于文件的大小

于 2011-03-19T17:17:38.560 回答