gpt4 book ai didi

mongodb - Mgo 拉取更新不起作用

转载 作者:IT王子 更新时间:2023-10-29 02:34:31 24 4
gpt4 key购买 nike

我正在尝试使用 Go 中的 mgo 库实现以下功能:

db.artists.update(
{_id: ObjectId("534944125117082b30000001")},
{
$pull: {
studies: {
_id: ObjectId("53d53591718a522e04000001")
}
}
})

这基本上是对艺术家收藏的更新,我试图根据它的 id 字段从研究数组中删除研究。

所以在 go 中我使用:

pullQuery := &bson.M{"studies": &bson.M{"_id": bson.ObjectIdHex("53d53fd6718a521954000001")}}
err = col.Update(&bson.M{"_id": "534944125117082b30000001"}, &bson.M{"$pull": pullQuery})

但这似乎行不通。如果我直接在 RoboMongo(mongodb 客户端实用程序)中运行第一个版本,它工作正常,但是对于 mgo,它似乎不起作用。它给我错误:“未找到”。

谢谢

编辑

修改了以下go代码,它只运行文件:

err = col.UpdateId(bson.ObjectIdHex("534944125117082b30000001"), &bson.M{"$pull": pullQuery})

最佳答案

您的第一个 $pull 示例中的 ObjectId 与 go 代码不匹配。您确定您使用的是正确的 _id 吗?

关于mongodb - Mgo 拉取更新不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24984029/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com