当前位置:首页 > 文章列表 > Golang > Go问答 > Golang中游标迭代时如何从mongodb记录中提取字段

Golang中游标迭代时如何从mongodb记录中提取字段

来源:stackoverflow 2024-04-13 20:00:32 0浏览 收藏

最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《Golang中游标迭代时如何从mongodb记录中提取字段》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

我对 golang 编程和 mongodb 接口相当陌生。

我有一个由另一个应用程序创建的记录数据库。我正在尝试遍历数据库并检查每条记录的特定字段。我可以将完整记录解码为 bson,但无法获取具体值。

这个结构定义了我想要提取的 3 个字段:

type mydbaserec struct {
    aid        string  `bson:"pon-util-aid"`
    ingresspct string  `bson:"ingress-bucket-percent"`
    egresspct  string  `bson:"egress-bucket-percent"`
}

这是我的代码,用于在集合后迭代光标。find(ctx, queryfilter) 并将结果解码为 bson 和我的结构:

    var myresult mydbaserec
    var bsonmresult bson.m

    var count int
    for cursor.next(ctx) {

        err := cursor.decode(&myresult)
        if err != nil {
            fmt.println("cursor.next() error:", err)
            panic(err)
            // if there are no cursor.decode errors
        } else {
            fmt.println("\nresult type:", reflect.typeof(myresult))
            fmt.printf("result: %+v\n", myresult)

        }

        err = cursor.decode(&bsonmresult)
        if err != nil {
            fmt.println("bson decode error:", err)
            panic(err)
            // if there are no cursor.decode errors
        } else {
            fmt.println("\nresult type:", reflect.typeof(bsonmresult))
            fmt.println("\nresult:", bsonmresult)
        }

    }

下面是循环一次迭代的示例。 bson 解码似乎可以工作,但我的结构是空的:

result type: internal.mydbaserec
result: {aid: ingresspct: egresspct:}

result type: primitive.m

result: map[pon-util-aid:rolt-1-montreal/1/1/xp2 _id:objectid("5d70b4d1b3605301ef72228b") 
admitted-assured-upstream-bw:0 admitted-excess-upstream-bw:0 admitted-fixed-upstream-bw:0 
assured-upstream-bytes:0 available-excess-upstream-bw:0 available-fixed-upstream-bw:622080 
app_counters_key_field:rolt-1-montreal/1/1/xp2 app_export_time:1567665626 downstream-octets:52639862633214 
egress-bucket-bps:8940390198 egress-bucket-percent:91 egress-bucket-seconds:559 
excess-upstream-bytes:0 fixed-upstream-bytes:0 ingress-bucket-bps:8253153852 
ingress-bucket-percent:84 ingress-bucket-seconds:559 sample-time:0 upstream-octets:48549268162714]

我本来希望得到

result: {aid:"ROLT-1-MONTREAL/1/1/xp2" ingressPct:84 egressPct:91}

关于如何从每条记录中正确查找这 3 个字段有什么建议吗?

===更新:下面的第一条评论回答了我的问题。


解决方案


首先,在 go 中,仅导出以 (unicode) 大写字母开头的字段。另请参阅 Exported identifiers。默认解码器将尝试仅解码导出的字段。所以你应该将结构更改为:

type myDbaseRec struct {
    Aid        string  `bson:"pon-util-aid"`
    IngressPct int32  `bson:"ingress-bucket-percent"`
    EgressPct  int32  `bson:"egress-bucket-percent"`
}

另请注意,上面的 ingresspctegresspct 结构的类型为 int32。这是因为文档中的值以数字(int/double)表示,而不是字符串。您可以相应地将其更改为其他数字类型,即 int16、int64 等。

以上就是《Golang中游标迭代时如何从mongodb记录中提取字段》的详细内容,更多关于的资料请关注golang学习网公众号!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
佳能EOS R5 Mark II即将亮相:规格升级,性能强大佳能EOS R5 Mark II即将亮相:规格升级,性能强大
上一篇
佳能EOS R5 Mark II即将亮相:规格升级,性能强大
Golang函数式编程在移动开发中的应用
下一篇
Golang函数式编程在移动开发中的应用
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 茅茅虫AIGC检测:精准识别AI生成内容,保障学术诚信
    茅茅虫AIGC检测
    茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
    148次使用
  • 赛林匹克平台:科技赛事聚合,赋能AI、算力、量子计算创新
    赛林匹克平台(Challympics)
    探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
    175次使用
  • SEO  笔格AIPPT:AI智能PPT制作,免费生成,高效演示
    笔格AIPPT
    SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
    165次使用
  • 稿定PPT:在线AI演示设计,高效PPT制作工具
    稿定PPT
    告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
    151次使用
  • Suno苏诺中文版:AI音乐创作平台,人人都是音乐家
    Suno苏诺中文版
    探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
    180次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码