我正在尝试从mongo文档中检索所有id和field2,如果field1等于某个值并且field2存在。
实施例: Mongo文件:
{
"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})
但我想在Go中使用Mgo包调用此查询。我无法使用Mgo转换make mongo查询调用。我尝试了几种方法,但它们似乎没有起作用。任何人都可以帮助我吗?
谢谢
答案 0 :(得分:2)
逻辑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