使用对象 ID 数组从 Golang 查询 MongoDB
在 MongoDB 中,您可以存储文档数组,每个文档都有自己唯一的 _id 。这允许您将多个文档与父文档关联。当使用 Golang 的 mgo 和 bson 包查询这些文档时,将 _id 数组转换为适当的类型非常重要。
解决方案
如果数组中的 _id 值只是十六进制字符串,提供的代码是正确的:
<code class="go">query := bson.M{"_id": bson.M{"$in": ids}} c.Find(query).All()</code>
但是,如果 _id 值是对象标识符(ObjectId),则需要将它们转换为正确的类型:
<code class="go">oids := make([]bson.ObjectId, len(ids)) for i := range ids { oids[i] = bson.ObjectIdHex(ids[i]) } query := bson.M{"_id": bson.M{"$in": oids}}</code>
此转换是必要的,因为 $in 运算符需要一个 ObjectId 值数组,而不是十六进制字符串。通过将十六进制字符串转换为ObjectId类型,您可以正确查询与提供的_id值关联的文档。
以上是如何使用对象 ID 数组从 Golang 查询 MongoDB?的详细内容。更多信息请关注PHP中文网其他相关文章!