golang中如何实现db事务的统一封装
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,小编给大家分享一下golang中如何实现db事务的统一封装,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!事务处理的流程示例
千家信息网最后更新 2025年11月08日golang中如何实现db事务的统一封装简单封装
偷懒第一步
偷懒第二步
偷懒第三步
进一步封装
小编给大家分享一下golang中如何实现db事务的统一封装,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
事务处理的流程示例
database := db.DB tx, err := database.Begin() if err != nil { return err } stmt, err := tx.Prepare(sqlQuery) if err != nil { tx.Rollback() return err } _, err = stmt.Exec(paras...) if err != nil { tx.Rollback() return err } err = tx.Commit() if err != nil { tx.Rollback() return err }以上是我们使用事务时的一般操作,如果每做一次事务的操作均要进行重新写一遍代码岂不是很麻烦,尤其是出错时,Rollback需要多次在不同错误的地方的进行调用处理。
简单封装
偷懒第一步
采用defer处理Rollback
defer tx.Rollback()
无论成功与否,均进行Rollback操作,只是有点影响,如果成功还调用Rollback的话,将会报错。虽然可以忽略,但作为程序员,有必要进一步调整。
偷懒第二步
根据执行结果来选择执行Rollback,避免无效使用。
defer func() { //根据执行结果选择执行Rollback if err != nil && tx != nil { log.Println("ExecSqlWithTransaction defer err :", err) tx.Rollback() } }()如此,我们就可以根据事务的执行结果决定是否Rollback了。
偷懒第三步
封装,以上代码本身就具有极大的普适性,因此,我们抽出通用的参数,将此过程封装成一个func,以后就可以直接调用了。
func ExecSqlWithTransaction(database *sql.DB, query string, args ...interface{}) (err error) { tx, err := database.Begin() if err != nil { return err } defer func() { if err != nil && tx != nil { tx.Rollback() } }() stmt, err := tx.Prepare(query) if err != nil { return err } defer stmt.Close() _, err = stmt.Exec(args...) if err != nil { return err } return tx.Commit()}封装后我们可以如下使用:
if err := ExecSqlWithTransaction(database,sqlQuery,paras...);err != nil{ //错误处理}封装后是不是很简洁啊?
进一步封装
在一个事务中可能会出现多个SELECT、UPDATE等操作,以上封装仅处理了一种操作,还不能满足我们的实际需求,因此需要更进一步封装。
func ExecSqlWithTransaction(db *sql.DB, handle func(tx *sql.Tx) error) (err error) { tx, err := db.Begin() if err != nil { return err } defer func() { if err != nil { tx.Rollback() } }() if err = handle(tx); err != nil { return err } return tx.Commit()}在handle func内可以直接使用事务tx进行增删改查。
以上是"golang中如何实现db事务的统一封装"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
封装
事务
处理
篇文章
结果
统一
成功
代码
内容
错误
进一
选择
不同
简洁
必要
更进一步
不怎么
参数
只是
地方
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
access数据库承载
选择软件开发职业的理由
大学生如何应对网络安全问题
连不上2k服务器ps4
联想视频管理器服务器
pc 软件开发必备
单位信息网络安全第一人
pta创建数据库题库答案
江西电脑软件开发学校
数据库字段插入逗号分隔的字符串
网络技术与高中英语阅读
青海曙光服务器维修调试虚拟主机
whmcs数据库版本
华为数通产品线软件开发
navicat怎么找数据库表
嘉定租房网络安全
建网站服务器流程
地产软件开发价格
mt管理器模拟服务器
内存数据库 重启
软件开发后产权归
软件开发属于什么付款用途
雅之网络技术有限公司怎么样
徐汇区网络技术研究售后服务
分布式数据库一致性xa
数据库管理工具是什么
东莞网络软件开发热线
单位信息网络安全第一人
人体姿势评估软件开发
服务器上可以搭建数据库吗