0

我正在使用 MongoDB 和 Perl。这是我的数据结构:

{
    "_id" : ObjectId("501976f8005c8b541d000000"),
    "err_id" : "err",
    "solution" : [
        {
            "attachment" : "attach",
            "macr" : "macrs",
            "yammer" : "yam",
            "resolution" : "l",
            "salesforce" : "salesforce",
            "username" : "bob"
        },
        {
            "attachment" : "attach",
            "macr" : "macrs",
            "yammer" : "yam",
            "resolution" : "losssss",
            "salesforce" : "salesforce",
            "username" : "bob"
        }
    ]
}

正如你所看到的,我有一个里面有对象的数组。我使用 Perl MongoDB 库创建了它。

我熟悉一些在 Perl MongoDB 库中操作数组的语法。例如,我使用它来查找用户名与$username.

$users->find({"solution.username" => $username});

我认为删除一个元素会很简单:

$users->remove({"solution.username" => $username});

但很可惜,事实并非如此。我试过这个并使用拉,但无济于事!我很难找到这个。有人知道根据其中一个字段的内容删除数组元素的语法吗?

4

1 回答 1

1

MongoDB::Collection remove()方法将删除与您的查询匹配的文档..所以绝对不是您要查找的内容。

要删除特定字段,您应该使用$unset

您的 solution.usernames 实际上是在一个数组中,因此您必须为要删除的字段包含一个数组索引,例如:

$users->update({"_id" => '123'}, {
   '$unset' => {
       'solution.0.username' => 1,
       'solution.1.username' => 1
   }
});

我不知道取消设置数组中匹配username的所有字段的更短语法,但您可以向命令添加多个字段。solutionsolution.#.username$unset

我上面的示例从数组中删除了前两个用户名条目。如果匹配的文档有两个以上的用户名条目,则每次运行此更新时,您最多会删除两个以上的条目(如果它们存在)。

于 2012-08-02T07:07:25.793 回答