Gone框架介绍23 - Gone对Xorm的一点点增强

gone是可以高效开发Web服务的Golang依赖注入框架
github地址:https://github.com/gone-io/gone
文档地址:https://goner.fun/zh/

Gone对Xorm的增强

1. 自动事务

使用Transaction函数包裹的函数,执行前会自动开启事务,返回error或者发生panic自动完成事务回滚,不返回error则自动提交事务。

注意:在Transaction函数包裹的数据库操作函数需要使用session xorm.Interface执行数据库操作

type db struct {
	gone.Flag
	gone.XormEngine `gone:"gone-xorm"` //注入数据库引擎
}

func (d *db) updateUser(user *entity.User) error {

    // 使用Transaction包裹的函数,执行前会自动开启事务
	return d.Transaction(func(session xorm.Interface) error {

        //注意:使用的session进行数据库操作
		_, err := session.ID(user.Id).Update(user)
		return gone.ToError(err)
	})
}

2. 事务自动传递

嵌套使用Transaction函数包裹的函数,只会开启一个事务,嵌套事务会自动传递,嵌套事务的error或者发生panic自动完成事务回滚,不返回error则自动提交事务。

这样带来一个好处,让我们编写的函数在组合时能够自动合并到一个事务中。

请看下面代码,如果updateUserupdateFriends函数单独使用,会分别开启事务;将他们嵌套在DoUpdateTransaction的函数中,则会合并到一个事务中。

type db struct {
	gone.Flag
	gone.XormEngine `gone:"gone-xorm"` //注入数据库引擎
}

func (d *db) updateUser(user *entity.User) error {

    // 使用Transaction包裹的函数,执行前会自动开启事务
	return d.Transaction(func(session xorm.Interface) error {

        //注意:使用的session进行数据库操作
		_, err := session.ID(user.Id).Update(user)
		return gone.ToError(err)
	})
}

func (d *db) updateFriends(userId int64, friedns []*entity.Friend) error {
	return d.Transaction(func(session xorm.Interface) error {
		//todo: 更新朋友的相关操作

		return nil
	})
}

func (d *db) DoUpdate(user *entity.User, friedns []*entity.Friend) error {
	return d.Transaction(func(session xorm.Interface) error {
		err := d.updateUser(user)
		if err != nil {
			return err
		}

		return d.updateFriends(user.Id, friedns)
	})
}

3. SQL支持名字参数

	sql, args := xorm.MustNamed(`
		update user
		set
		    status = :status,
			avatar = :avatar
		where
		    id = :id`,
		map[string]any{
			"id":     1,
			"status": 1,
			"avatar": "https://wwww....",
		},
	)

通过xorm.MustNamed处理后的sql为:

update user
set
    status = ?,
    avatar = ?
where
    id = ?

args[]any类型,值为:1,1,"https://wwww...."

求赞助

如果觉得还可以,请帮忙在github上点个 ⭐️吧:
github地址:https://github.com/gone-io/gone

福利🔥添加交流群,赠送 Golang 多套 学习资料,夯实基础👍🏻👍🏻

上一篇:Gone框架介绍22 - 错误处理,Web开发的错误我们这么干的
下一篇:Gone框架介绍24 - Gone vs Spring,写给需要转 Go 的 Java程序员

  • 11
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

dapeng-大鹏

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

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

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

打赏作者

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

抵扣说明:

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

余额充值