Go事务失效主因是操作未绑定到同一sql.Tx:BeginTx后必须用tx.Exec()等,禁用db.Exec();Savepoint需手写SQL;context超时不中断已执行SQL;ORM传sql.Tx仅接口兼容,未必进事务。Go 里 BeginTx 和 Exec 不在同一个 *sql.Tx 上,事务就白做了事务失效最常见原因:没把后续操作绑定到事务对象上。比如用 db.BeginTx() 开启事务,但后面还用 db.Exec()(属于原始 *sql.DB),那这些语句根本不在事务里,各自自动提交。所有 SQL 操作必须调用 tx.Query()、tx.Exec()、tx.Prepare() 等,不能混用 db.Xxx()注意 sql.Tx 不是线程安全的,别跨 goroutine 复用如果用了 database/sql 的连接池,tx 会独占一个底层连接,直到 Commit() 或 Rollback()PostgreSQL 中 Savepoint 在 Go 里得手写 SQL,标准库不支持Go 标准 database/sql 没提供 Savepoint 接口,想实现嵌套回滚或部分回滚,只能手动执行 SAVEPOINT sp1 和 ROLLBACK TO SAVEPOINT sp1。必须确保 tx 支持该方言(PostgreSQL/MySQL 8.0+ 可以,SQLite 行,但 MySQL 5.7 不支持 SAVEPOINT)Savepoint 名字要自己管理,避免重复;建议用 uuid.NewString() 或带上下文前缀的字符串执行失败时,记得检查错误是否来自 savepoint 操作本身(比如语法错),别和业务逻辑错误混淆context.WithTimeout 传给 BeginTx,但事务超时后连接不一定立刻释放传入 context 控制事务生命周期是对的,但要注意:超时触发后,BeginTx 会返回 error,可如果已经拿到 *sql.Tx,它的底层连接不会自动关闭,得靠连接池空闲回收或 DB 设置 SetConnMaxLifetime。 Tellers AI Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
学弟21 小时前
【内涵】深度学习中的三种变量及pytorch中对应的三种tensor2301_7775993721 小时前
mysql如何进行数据库容量规划_评估磁盘空间增长趋势aq553560021 小时前
PHP vs Python:30秒看懂核心区别NineData21 小时前
NineData 亮相香港国际创科展 InnoEX 2026,以 AI 加速布局全球市场m0_3776182321 小时前
Redis怎样应对大规模集群的重启风暴_分批次重启节点并等待集群状态恢复绿灯后再继续操作心态与习惯1 天前
Julia 初探,及与 C++,Java,Python 的比较imuliuliang1 天前
存储过程(SQL)考虑考虑1 天前
SQL语句中的order by可能造成时间重复ZC跨境爬虫1 天前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)zopple1 天前
ThinkPHP5.x与3.x核心差异解析