golang gorm —— 事务、回滚、savepoint

2023-10-11 06:28

本文主要是介绍golang gorm —— 事务、回滚、savepoint,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

gorm事务

model定义

type Roles []stringtype Teacher struct {gorm.ModelName     string   `gorm:"size:256"`Email    string   `gorm:"size:256"`Salary   float64  `gorm:"scale:2;precision:7"`   // 指定小数部分宽度为2,列宽度为7. 列宽:【整数部分+小数部分的总长度】【不含小数点】Age      uint8    `gorm:"check:age>30"`Birthday int64    `gorm:"serializer:unixtime;type:time"`  // 反序列化方式 unixtime, 类型为timeRoles    Roles    `gorm:"serializer:json"`JobInfo  Job      `gorm:"embedded;embeddedPrefix:job_"`   // 嵌套字段, 嵌入字段的列名前缀job_JobInfo2 Job      `gorm:"type:bytes;serializer:gob"`      // 字节流类型,gob反序列化,go自己的序列化方法,跨语言项目的时候,不建议用
}type Job struct {Title    stringLocation string
}type Course struct {gorm.ModelName   string  `gorm:"size:256"`Price  float64 `gorm:"scale:2;precision:7"`UserID uint    `gorm:"type:int"`
}
自动事务

gorm提供了自动事务的机制,不需要我们手动提交和回滚

func Transaction() {t := Teacher{Name:   "yuan",Age:    41,Salary: 122345.123,Email:  "yuan@test.com",}c := Course{Name:  "golang",Price: 12345.1234,}DB.Transaction(func(tx *gorm.DB) error {if err := tx.Create(&t).Error; err != nil {// 返回err 会自动回滚事务return err}c.UserID = t.IDif err := tx.Create(&c).Error; err != nil {return err}// 返回nil 则提交事务return nil})
}
嵌套事务

gorm事务可以嵌套,大事务里嵌套小事务,只有大事务成功提交,必须大事务提交成功,内部嵌套的事务才能提交成功。如果失败了,可以回滚嵌套的事务。

注意:嵌套事务不应在gorm中大量使用,因为其不支持预编译

func NestTransaction() {t := Teacher{Name:   "yuan",Age:    41,Salary: 122345.123,Email:  "yuan@test.com",}t1 := Teacher{Name:   "yuan2",Age:    40,Salary: 12345.123,Email:  "yuan@test.com",,}t2 := Teacher{Name:   "yuan3",Age:    50,Salary: 12345.123,Email:  "yuan@test.com",,}DB.Transaction(func(tx *gorm.DB) error {if err := tx.Create(&t).Error; err != nil {return err}tx.Transaction(func(tx1 *gorm.DB) error {if err := tx1.Create(&t1).Error; err != nil {return err}return nil})tx.Transaction(func(tx1 *gorm.DB) error {if err := tx1.Create(&t2).Error; err != nil {return err}return nil})return nil})
}
手动事务

gorm也提供了begin, rollback等接口支持手动事务的操作

func ManualTransaction() {t := Teacher{Name:   "yuan",Age:    41,Salary: 122345.123,Email:  "yuan@test.com",}c := Course{Name:  "golang",Price: 12345.1234,}tx := DB.Begin()defer func() {if err := recover(); err != nil {tx.Rollback()}}()if tx.Error != nil {log.Fatal(tx.Error)return}if err := tx.Create(&t).Error; err != nil {tx.Rollback()return}c.UserID = t.IDif err := tx.Create(&c).Error; err != nil {tx.Rollback()return}tx.Commit()
}
检查点savePoint

gorm也提供了savePoint的机制来支持事务的分段提交,回滚到某个特定的savePoint(RollbackTo)

func SavePointTransaction() {t := Teacher{Name:   "yuan",Age:    41,Salary: 122345.123,Email:  "yuan@test.com",}c := Course{Name:  "golang",Price: 12345.1234,}tx := DB.Begin()defer func() {if err := recover(); err != nil {tx.Rollback()}}()if tx.Error != nil {log.Fatal(tx.Error)return}if err := tx.Create(&t).Error; err != nil {tx.Rollback()return}// 创建savepointtx.SavePoint("teacher")c.UserID = t.IDif err := tx.Create(&c).Error; err != nil {// 回滚到对应savepointtx.RollbackTo("teacher")return}tx.Commit()
}

这篇关于golang gorm —— 事务、回滚、savepoint的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/186172

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

MySQL 事务的概念及ACID属性和使用详解

《MySQL事务的概念及ACID属性和使用详解》MySQL通过多线程实现存储工作,因此在并发访问场景中,事务确保了数据操作的一致性和可靠性,下面通过本文给大家介绍MySQL事务的概念及ACID属性和... 目录一、什么是事务二、事务的属性及使用2.1 事务的 ACID 属性2.2 为什么存在事务2.3 事务