首页 > 后端开发 > Golang > 正文

如何将 db.QueryRow(sql).Scan 结果扫描至 map?

聖光之護
发布: 2024-11-04 09:18:16
原创
367人浏览过

如何将 db.queryrow(sql).scan 结果扫描至 map?

利用 db.queryrow(sql).scan 将结果集扫描至 map

在 go 中,db.queryrow(sql).scan 只能将结果集扫描至变量指针,而无法直接扫描至 map。以下示例会提示扫描目标不是指针的错误:

res := map[string]*interface{}{"id": nil, "name": nil, "password": nil, "add_time": nil}

sql := "select * from test where id = ?"
err := db.queryrow(sql, id).scan(res["id"], res["name"], res["password"], res["add_time"])
登录后复制

为了解决这个问题,需要对 map 进行初始化以提供指针:

res := map[string]*interface{}{
    "id":       new(int),
    "name":     new(string),
    "password": new(string),
    "add_time": new(int),
}
登录后复制

这样,res 中的每一个值都将成为一个指针,指向实际数据。然后,db.queryrow(sql).scan 就可以将结果集扫描至 res 中。

修改后的示例:

func selectOne(id int) {
    res := map[string]*interface{}{
        "id":       new(int),
        "name":     new(string),
        "password": new(string),
        "add_time": new(int),
    }

    sql := "select * from test where id = ?"
    err := db.QueryRow(sql, id).Scan(res["id"], res["name"], res["password"], res["add_time"])

    if err != nil {
        fmt.Println("获取数据失败:", err.Error())
    } else {
        fmt.Println(res)
    }
}
登录后复制

以上就是如何将 db.QueryRow(sql).Scan 结果扫描至 map?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号