MongoDB - 来自doc的Mongoose Array Pull

时间:2014-12-19 14:50:40

标签: node.js mongodb mongoose

我对mongoose的pull方法感到有些困惑,你只能通过objectID拉动,还是只需要通过数据模型中的值拉?

无论哪种方式,我都无法从数组中删除元素。

以下是模型:

var fieldSchema = new Schema({
    'name' : String,
    'value' : String
});

var formSchema = new Schema({
    'name' : String,
    'fields' : [fieldSchema]
});

var userSchema = new Schema({
    'email' : String,
    'firstName' : String,
    'lastName' : String,
    'application' : [formSchema]
});

var fieldModel = mongoose.model('field',fieldSchema);
var formModel = mongoose.model('form',formSchema);
var userModel = mongoose.model('user',userSchema);

代码(数据库中只有一个doc,这就是为什么findOne没有参数):

userModel.findOne({}, function (err, user) {
  if (err) return handleError(err);

  var edit = false;

  for(i in user.application) {
    if(user.application[i].name == submit.name) {
      edit = true;

      user.application.pull({'name':submit.name}); //is this valid?
      user.application.push(submit);
    }
  }
  console.log(edit);
  if(!edit) {
    user.application.push(submit);
  }

  user.save(function(err, doc, numAffected) {
    if (err) console.log(err);
    else {
      console.log('number of rows: ' + numAffected);
      doc.save();
    }
  });

});

DB中的文档:

"_id" : ObjectId("5490f0cdd059b4cdb6bdf7d2"),
"email":"test@test.com",
"firstName":"tester",
"lastName":"tester",
"application" : [
    {
        "name" : "Contact",
        "fields" : [
            {
                "field_name" : "New field - 1",
                "field_value" : "kkkkkkk"
            }
        ]
    }
],

1 个答案:

答案 0 :(得分:1)

使用下面的代码更改你的第二个代码,因为user.application是javascript数组并且没有pull方法从数组中删除元素,所以你不允许使用它,因为你可以在mongoDB查询中使用$ pull,在这种情况下,不建议使用for(i in user.application)

userModel.update({'application.name':submit.name},{$push:{application:submit}},function (err, user) {
  if(user===0){
    userModel.update({},{$push:{application:submit}},function(){

    })
  }

});