gpt4 book ai didi

mongodb - 将 Mongo 查询转换为 Mgo 查询

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

我正在尝试从 mongo 文档中检索所有 id 和 field2,如果 field1 等于某个值并且 field2 存在的话。

例子:蒙戈文档:

{

"id": "id1"
"field1": "val1"
"field2": "val2"
"field3": "val3"
}

{

"id": "id2"
"field1": "val4"
"field3": "val5"
}

结果

{

"id" : "id1"
"field2": "val2"
}

我找到了可行的 mongodb 查询:

dbname.find( { $and: [ { "field1": "val1" }, { "field2": { $exists: true } } ] } , {"id":1, "field2":1})

但我想使用 Mgo 包在 Go 中调用此查询。我无法使用 Mgo 转换 make this mongo query call。我尝试了几种方法,但它们似乎没有用。有人可以帮我吗?

谢谢

最佳答案

逻辑 AND 是默认值,因此您可以慷慨地将其省略:

dbname.find({"field1": "val1", "field2": {$exists: true}, {"id": 1, "field2": 1})

mgo 中:

一般只用 bson.M每个括号的映射值(其中键必须是 string 值)。投影用Query.Select() .

sess := ... // Acquire an mgo session

c := sess.DB("dbname").C("collname") // Use your db name and collection name

var docs []bson.M
err := c.Find(bson.M{
"field1": "val1",
"field2": bson.M{"$exists": true},
}).Select(bson.M{"id": 1, "field2": 1}).All(&docs)

if err != nil {
// Handle err
log.Printf("Query error: "%v", err)
return
}

// Process results

关于mongodb - 将 Mongo 查询转换为 Mgo 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47025936/

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