当前位置: 首页 > news >正文

【go】gorm\xorm\ent事务处理

文章目录

  • 1 gorm
      • 1.1 开启事务
      • 1.2 执行操作
      • 1.3 提交或回滚
  • 2 xorm
      • 2.1 开启事务
      • 2.2 执行操作
      • 2.3 提交或回滚
  • 3 ent
      • 3.1 开启事务
      • 3.2 执行操作
      • 3.3 提交或回滚

前言:本文介绍golang三种orm框架对数据库事务的操作

1 gorm

Begin开启事务
tx *gorm.DB

1.1 开启事务

tx := db.Begin()

1.2 执行操作

if err := tx.Create(&User{Name: "Amy"}).Error; err != nil {tx.Rollback()return err
}

1.3 提交或回滚

if err := tx.Commit().Error; err != nil {tx.Rollback()return err
}

2 xorm

NewSession开启事务
tx *xorm.Session

2.1 开启事务

tx: = db.NewSession()
defer tx.Close()
err = tx.Begin()
if err != nil {return err
}

2.2 执行操作

_, err := tx.Table("test").Insert(&users)
if err != nil {tx.Rollback()return err
}

2.3 提交或回滚

err = tx.Commit()
if err != nil {tx.Rollback()return err
}

3 ent

Tx开启事务
tx *ent.Tx

3.1 开启事务

tx, err := db.Tx(ctx)
if err != nil {return err
}

3.2 执行操作

err := tx.User.Create().SetID("aaa").SetAction("create").SetName("amy").Save(ctx)
}
if err != nil {tx.Rollback()return err
}

3.3 提交或回滚

if err := tx.Commit(); err != nil {tx.Rollback()return err
}
http://www.lryc.cn/news/297354.html

相关文章:

  • 【数据分享】1929-2023年全球站点的逐月平均风速(Shp\Excel\免费获取)
  • IP地址详解
  • Python爬虫http基本原理#2
  • Web Services 服务 是不是过时了?创建 Web Services 服务实例
  • redis单线程还快的原因
  • 【flutter】报错 cmdline-tools component is missing
  • 以用户为中心,酷开科技荣获“消费者服务之星”
  • Days 27 ElfBoard 板 AltiumDesigner 相同电路快速布局布线
  • 除夕快乐(前端小烟花)
  • fast.ai 深度学习笔记(二)
  • 风行智能电视G32Y 强制刷机升级方法,附刷机升级数据MstarUpgrade.bin
  • tsgctf-2021-lkgit-无锁竞争-userfaultfd
  • 物联网数据隐私保护技术
  • RabbitMQ-1.介绍与安装
  • CSS高级技巧
  • Redis的数据类型Hash使用场景实战
  • HttpClient | 支持 HTTP 协议的客户端编程工具包
  • DP第一天:力扣● 理论基础 ● 509. 斐波那契数 ● 70. 爬楼梯 ● 746. 使用最小花费爬楼梯
  • Android Studio 安装Flutter插件但是没法创建项目
  • 新春快乐(烟花、春联)【附源码】
  • nextcloud 优化扩展
  • 【CSS】css如何实现字体大小小于12px?
  • 【Langchain+Streamlit】旅游聊天机器人
  • 〖大前端 - ES6篇②〗- let和const
  • JAVA设计模式之代理模式详解
  • vivo发布2023 年度科技创新;阿里全新AI代理,可模拟人类操作手机
  • 【制作100个unity游戏之23】实现类似七日杀、森林一样的生存游戏15(附项目源码)
  • python巧用定理判断素数
  • 2023年总结
  • Git中为常用指令配置别名