2

我想从存储在 mongodb 文档中的数组中删除特定元素。我正在使用这个:

 model.registerCompany.findOneAndUpdate({companyKey:"a key"},
    {$pop:{onlineEmployees:"John"}},
    function(err,doc){
    if(!err)
        console.log("Online list modified: ",doc);
    else
        console.log("Online list modified error :",err);
});

但我不确定 $pop 是从 array(onlineEmployees) 中删除特定元素“John”还是只是从中弹出最后一个元素。

我做得对还是有其他方法可以做到。

我想我得到了答案.. $pull 用于此目的,如链接中所述:http: //docs.mongodb.org/manual/reference/operator/pull/#_S_pull

4

1 回答 1

13

$pop运算符将删除数组的第一个或最后一个元素,这不一定是正确的。

如果你想要一个特定的元素,你可以$pull具有定义条件的项目:

   model.registerCompany.findOneAndUpdate({companyKey:"a key"},
    {$pull:{onlineEmployees:"John"}},

您必须确保数组中的值是唯一的,以便$pull删除与名称“John”匹配的每个元素。

如果数组中存在相同的值,则需要使用$unsetand$位置运算符将目标元素值设置为null(遗憾的是 $unset 不会删除元素),然后使用$pull删除具有null值的元素。为此,您必须确保有效值不能是null. 在这种情况下,代码可能类似于:

model.registerCompany.findOneAndUpdate({companyKey:"a key", onlineEmployees:"John"},{ $unset: { "onlineEmployees.$" : '' } } ) 
model.registerCompany.findOneAndUpdate({companyKey:"a key"},{ $pull: { "onlineEmployees" : null } } ) 
于 2013-01-23T09:16:22.673 回答