我对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"
}
]
}
],
答案 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(){
})
}
});