1

我正在使用 node 和 mongodb,并且在从我的集合中的数组中删除子文档时遇到问题,我似乎无法弄清楚。

我的“cardHolders”集合中的示例文档如下所示(为简洁起见,去掉了其他字段):

{
    "_id" : ObjectId("51ee899ec15d5aaff39d3352"),
    "cards" : [
            {
               "rfid_id" : ObjectId("51ee899ec15d5aaff39d335a")
            }
    ]
}

我正在尝试做的是在卡片数组中找到所有具有 rfid_id 值的子文档的 cardHolder 文档。

我试过 mongo 命令:

db.cardholders.update({}, 
    {$pull:{ "cards": {"rfid_id": ObjectId("51ee899ec15d5aaff39d335a")}}},
    false, false)

虽然我没有收到任何语法错误,但我的收藏中的任何文档都不会受到影响 - 非常感谢您对此事的任何帮助!

使用完整的文档详细信息进行编辑:

{
    "_id" : ObjectId("51ee899ec15d5aaff39d3353"),
    "first" : "first",
    "last" : "last",
    "email" : "email",
    "phone" : "555 555 5555",
    "userRole" : "su",
    "cards" : [
            {
                    "rfid_id" : ObjectId("51ee899ec15d5aaff39d3359")
            }
    ],
    "zones" : [
            {
                    "zone_id" : ObjectId("51ee899ec15d5aaff39d3357")
            }
    ]
}
4

1 回答 1

3

你的例子工作得很好:

db.so.drop();
db.so.insert(
{
    "_id" : ObjectId("51ee899ec15d5aaff39d3353"),
    "first" : "first",
    "last" : "last",
    "email" : "email",
    "phone" : "555 555 5555",
    "userRole" : "su",
    "cards" : [
            {
                    "rfid_id" : ObjectId("51ee899ec15d5aaff39d3359")
            }
    ],
    "zones" : [
            {
                    "zone_id" : ObjectId("51ee899ec15d5aaff39d3357")
            }
    ]
});

db.so.update({}, {$pull:{ "cards": {"rfid_id": ObjectId("51ee899ec15d5aaff39d3359")}}}, false, false)
db.so.find().pretty();

输出:

{
    "_id" : ObjectId("51ee899ec15d5aaff39d3353"),
    "cards" : [ ],
    "email" : "email",
    "first" : "first",
    "last" : "last",
    "phone" : "555 555 5555",
    "userRole" : "su",
    "zones" : [
        {
            "zone_id" : ObjectId("51ee899ec15d5aaff39d3357")
        }
    ]
}

尽管我确实必须稍微更改拉取的 ObjectID,因为它最初在文档的简单版本和完整版本之间使用不同的字符串。

于 2013-07-24T10:05:26.387 回答