为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用 mongo-driver/mongo 查找具有多个条件的文档

如何使用 mongo-driver/mongo 查找具有多个条件的文档

Go
慕后森 2023-08-07 11:11:39
查询以下数据时,返回的游标为空。而满足条件的文档有上百个。 {  "_id": "5dd68c51a39809125944ffba",  "status": "success",  "balance": "0.000",  "request_params": {   "username": "test_user",   "service_code": "MR" }使用下面的代码MongoDB 驱动程序“go.mongodb.org/mongo-driver/mongo”func saveLog(data Log) bool {    mongo, err := openMongo()    if err != nil {        log.Println(err)        fmt.Println("Connection failed")        return false    } else {        LogCollection := mongo.Database(LogDb).Collection(CollectionLog)        insertedApi, err := LogCollection.InsertOne(context.TODO(), data)        if err != nil {            log.Println(err)            fmt.Println("Insert failed")            return false        } else {            log.Println(insertedApi.InsertedID)            return true        }    }}func parseLog() {    db, err := openMongo()    if err != nil {        fmt.Println(err)        fmt.Println("Connection failed")        return    } else {        logCollection := db.Database(LogDb).Collection(CollectionLog)        var results [] *Log        find := bson.D{{"status","success"},{"request_params",bson.D{{"username","test_user"}}}}        fmt.Println(find)        cur, err := logCollection.Find(context.TODO(), find)        if err != nil {            log.Fatal(err)        }else {            for cur.Next(context.TODO()) {                var elem Log                err := cur.Decode(&elem)                if err != nil {                    fmt.Println("Parse error : ",err)                }                fmt.Println("Log : ",elem)                results = append(results, &elem)            }        }    }}日志写入saveLog(Log{"success","0.000",RequestParams{"test_user","MR"}})日志读取parseLog()日志结构type Log struct {    Status string `bson:"status"`    Balance string `bson:"balance"`    RequestParams RequestParams `bson:"request_params"`}type RequestParams struct {    Username string `bson:"username"`    ServiceCode     string `bson:"service_code"`}MongoDB 数据
查看完整描述

1 回答

?
慕尼黑5688855

TA贡献1848条经验 获得超2个赞

这里的问题是由于查询过滤器造成的。以下查询之间存在差异:


// Query A: {"status": "success", "request_params": {"username":"test_user"}}

find := bson.D{{"status","success"},{"request_params",bson.D{{"username","test_user"}}}}


// Query B: {"status": "success", "request_params.username":"test_user"}

find := bson.D{{"status","success"},{"request_params.username","test_user"}}

查询 A 意味着您希望匹配request_params值对象完全等于 的精确文档{"username":"test_user"}。您的收藏中没有任何文档符合此条件。该文档还包含{"service_code":"MR"}. 而查询 B 使用点表示法,这意味着您希望匹配包含值 的request_params字段。{"username":"test_user"}

查看完整回答
反对 回复 2023-08-07
  • 1 回答
  • 0 关注
  • 63 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信