Go语学习笔记 - gorm使用 - 事务操作 | Web框架Gin(十一)

学习笔记,写到哪是哪。

接着上一篇文章:Go语学习笔记 - gorm使用 - gorm处理错误 | Web框架Gin(十)_剑客阿良_ALiang的博客-CSDN博客

在项目中事务处理,回滚操作还是比较常见的需求。

本文测试一下gorm的事务处理效果。

项目地址:github地址

如果没有事务方面需求,也是可以全局禁用事务的,官方给出的性能提升是30%。

在student_service下新增TestTransaction方法。

方法代码如下:

//测试事务效果
func (t StudentImpl) TestTransaction() rsp.ResponseMsg {
	log.Logger.Info("测试事务效果")
	_db := mysql.GetDB()
	_db.Transaction(func(tx *gorm.DB) error {
		tx.Create(&db_entity.Student{
			Name: "张飞", Age: 200,
		})
		var _student db_entity.Student
		if _err := tx.Where("del_flag = 1").First(&_student).Error; _err != nil {
			return _err
		}
		fmt.Println(_student)
		return nil
	})
	return *rsp.SuccessMsg("测试成功")
}

简单说明

1、使用Transaction定义需要处理的事务方法,先创建一条数据,再构造一个异常。

2、如果异常了,按照事务处理方式,创建的数据也不会提交。

controller层增加接口代码,如下:

//测试事务效果
func (s StudentController) TestTransaction(context *gin.Context) {
	log.Logger.Info("测试事务效果")
	_rsp := services.StudentServ.TestTransaction()
	context.JSON(http.StatusOK, _rsp)
}

测试效果

 

 

可以看出数据并没有插入到表中。

注意 

感觉有个地方还是容易出错的,在Transaction定义事务方法的时候,方法内不要在使用db去处理,而是传参tx。不然并不会按照事务方式去处理。

小结

没啥好总结的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

剑客阿良_ALiang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值