SQLx查单行必须用Get而非QueryRow,以启用StructScan;Exec仅用于无结果集的增删改,RETURNING需配Get/Select;命名参数仅PostgreSQL原生支持,MySQL/SQLite需用位置参数或Rebind。SQLx 查询单行数据用 Get,别用 QueryRowSQLx 封装了 database/sql,但直接调 QueryRow 会绕过 SQLx 的结构体自动扫描能力,导致字段映射失败或 panic。正确做法是统一走 SQLx 提供的 Get(查单行)或 Select(查多行)。常见错误现象:sql: Scan error on column index 0: unsupported driver -> Scan pair: *string -> *interface{}------本质是没让 SQLx 知道目标结构体类型。Get 内部会调用 QueryRow,但额外做了 StructScan,必须传入地址(&user)结构体字段需有对应 tag,如 db:"id",否则按字段名全小写匹配列名如果查不到数据,Get 返回 sql.ErrNoRows,不是 nilvar user Usererr := db.Get(&user, "SELECT id, name FROM users WHERE id = $1", 123)SQLx 执行原生 INSERT/UPDATE/DELETE 用 Exec,返回 sql.Result和 database/sql 一样,增删改不返回结果集,只关心影响行数或最后插入 ID。SQLx 的 Exec 和标准库行为一致,但支持命名参数(需配合 NamedQuery)。使用场景:需要获取自增 ID 或判断是否成功更新某条记录。立即学习"go语言免费学习笔记(深入)"; 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具
相关推荐
m0_743623922 小时前
mysql如何优化InnoDB缓冲池大小_mysql缓冲池内存调优孟意昶2 小时前
Doris专题31-SQL手册-基础元素m0_617881422 小时前
如何操作 XML 数据_XMLTYPE 与 EXTRACT 函数解析节点qq_334563552 小时前
golang如何实现SSTable持久化_golang SSTable持久化实现要点2301_777599372 小时前
Redis怎样应对大规模集群的重启风暴_分批次重启节点并等待集群状态恢复绿灯后再继续操作qq_452396232 小时前
【工程实战】第十篇:性能监控集成 —— 自动化脚本的“副产品”:不仅仅是功能测试一只小白0002 小时前
Redis 常用命令总结来自远方的老作者2 小时前
第10章 面向对象-10.4 继承逻辑驱动的ken2 小时前
Java高频面试考点场景题09