arrays - 获取嵌套数组中具有特定ObjectId的数组对象

标签 arrays mongodb go aggregate mgo

我正在尝试根据对象拥有的 ObjectId 获取特定的对象数组。

这是我的 MongoDB 数据库:

{
    "_id" : ObjectId("59edb571593904117884b721"),
    "userids" : [
            ObjectId("59edb459593904117884b71f")
    ],
    "macaddress" : "MACADDRESS",
    "devices" : [ ],
    "projectorbrand" : "",
}
{
    "_id" : ObjectId("59edb584593904117884b722"),
    "userids" : [
            ObjectId("59edb459593904117884b71f"),
            ObjectId("59e4809159390431d44a9438")
    ],
    "macaddress" : "MACADDRESS2",
    "devices" : [ ],
    "projectorbrand" : "",
}

MongoDB中的命令是:

db.getCollection('co4b').find( {
    userids: { $all: [ ObjectId("59edb459593904117884b71f") ] }
} )

这将起作用并将返回正确过滤的数组。 我想用 Golang 翻译这个查询。

这是我的代码:

pipe := bson.M{"userids": bson.M{"$all": objectId}}
var objects[]models.Objects
if err := uc.session.DB("API").C("objects").Pipe(pipe).All(&objects); err != nil {
    SendError(w, "error", 500, err.Error())
} else {
    for i := 0; i < len(objects); i++ {
        objects[i].Actions = nil
    }
    uj, _ := json.MarshalIndent(objects, "", " ")
    SendSuccessJson(w, uj)
}

我收到类似字段(管道)3 != 4 类型错误之类的错误。我看到 $all 需要字符串数组,但如何通过 ObjectId 而不是字符串进行过滤?

感谢帮助

最佳答案

您正在尝试在 mgo 解决方案中使用聚合框架,但您尝试实现的查询不使用聚合框架(也不需要聚合框架)。

查询:

db.getCollection('co4b').find({
    userids: {$all: [ObjectId("59edb459593904117884b71f")] }
})

可以简单地转换为 mgo,如下所示:

c := uc.session.DB("API").C("objects")

var objects []models.Objects
err := c.Find(bson.M{"userids": bson.M{
    "$all": []interface{}{bson.ObjectIdHex("59edb459593904117884b71f")},
}}).All(&objects)

另请注意,如果您将 $all 与单个元素一起使用,您还可以使用 $elemMatch 实现该查询,在 MongoDB 控制台中会这样:

db.getCollection('co4b').find({
    userids: {$elemMatch: {$eq: ObjectId("59edb459593904117884b71f")}}
})

mgo 中看起来像这样:

err := c.Find(bson.M{"userids": bson.M{
    "$elemMatch": bson.M{"$eq": bson.ObjectIdHex("59edb459593904117884b71f")},
}}).All(&objects)

关于arrays - 获取嵌套数组中具有特定ObjectId的数组对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46892083/

相关文章:

javascript - 在相同的 $ajax 请求中将变量和数组从 JQuery 发布到 PHP

Javascript:为了不间断显示图片,试图重构这么多IF语句

javascript - 无法从模板获取数据并将其传递给 Controller ​​ Angularjs

csv - 使用 Goroutines 同时加载大型 CSV 时的未定义行为

c++ - 声明后初始化 boost::array

Javascript - 通过引用对数组进行排序

javascript - 如何通过许多$项目来改进这个总量

mongodb - 在hos上创建具有本地存储的mongo docker容器

go - 在 Postman 中填写请求正文

opengl - glClear() 在 Intel HD 4000 (GL 4.0) 上提供 GL_OUT_OF_MEMORY 但在 GeForce (GL 4.2) 上不提供......为什么?