網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
禁用默認(rèn)事務(wù)
為了確保數(shù)據(jù)一致性,GORM 會(huì)在事務(wù)里執(zhí)行寫入操作(創(chuàng)建、更新、刪除)。如果沒(méi)有這方面的要求,您可以在初始化時(shí)禁用它,這將獲得大約 30%+ 性能提升。
// 全局禁用 db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{ SkipDefaultTransaction: true, }) // 持續(xù)會(huì)話模式 tx := db.Session(&Session{SkipDefaultTransaction: true}) tx.First(&user, 1) tx.Find(&users) tx.Model(&user).Update("Age", 18)
事務(wù)
要在事務(wù)中執(zhí)行一系列操作,一般流程如下:
db.Transaction(func(tx *gorm.DB) error { // 在事務(wù)中執(zhí)行一些 db 操作(從這里開(kāi)始,您應(yīng)該使用 'tx' 而不是 'db') if err := tx.Create(&Animal{Name: "Giraffe"}).Error; err != nil { // 返回任何錯(cuò)誤都會(huì)回滾事務(wù) return err } if err := tx.Create(&Animal{Name: "Lion"}).Error; err != nil { return err } // 返回 nil 提交事務(wù) return nil })
嵌套事務(wù)
GORM 支持嵌套事務(wù),您可以回滾較大事務(wù)內(nèi)執(zhí)行的一部分操作,例如:
db.Transaction(func(tx *gorm.DB) error { tx.Create(&user1) tx.Transaction(func(tx2 *gorm.DB) error { tx2.Create(&user2) return errors.New("rollback user2") // Rollback user2 }) tx.Transaction(func(tx2 *gorm.DB) error { tx2.Create(&user3) return nil }) return nil }) // Commit user1, user3
手動(dòng)事務(wù)
// 開(kāi)始事務(wù) tx := db.Begin() // 在事務(wù)中執(zhí)行一些 db 操作(從這里開(kāi)始,您應(yīng)該使用 'tx' 而不是 'db') tx.Create(...) // ... // 遇到錯(cuò)誤時(shí)回滾事務(wù) tx.Rollback() // 否則,提交事務(wù) tx.Commit()
一個(gè)特殊的示例
func CreateAnimals(db *gorm.DB) error { // 再嘮叨一下,事務(wù)一旦開(kāi)始,你就應(yīng)該使用 tx 處理數(shù)據(jù) tx := db.Begin() defer func() { if r := recover(); r != nil { tx.Rollback() } }() if err := tx.Error; err != nil { return err } if err := tx.Create(&Animal{Name: "Giraffe"}).Error; err != nil { tx.Rollback() return err } if err := tx.Create(&Animal{Name: "Lion"}).Error; err != nil { tx.Rollback() return err } return tx.Commit().Error }
SavePoint、RollbackTo
GORM 提供了?SavePoint
、Rollbackto
?來(lái)提供保存點(diǎn)以及回滾至保存點(diǎn),例如:
tx := db.Begin() tx.Create(&user1) tx.SavePoint("sp1") tx.Create(&user2) tx.RollbackTo("sp1") // Rollback user2 tx.Commit() // Commit user1
原文鏈接:https://learnku.com/docs/gorm/v2/transactions/9745
相關(guān)推薦
- 2022-07-04 PyG搭建GCN模型實(shí)現(xiàn)節(jié)點(diǎn)分類GCNConv參數(shù)詳解_python
- 2022-08-21 python格式的Caffe圖片數(shù)據(jù)均值計(jì)算學(xué)習(xí)_python
- 2022-04-20 Python?設(shè)計(jì)模式行為型解釋器模式_python
- 2022-01-20 關(guān)于 Symbol() 能不能當(dāng)作 key值使用
- 2022-06-21 python繪制帶有色塊的折線圖_python
- 2022-11-18 使用sealos快速搭建K8s集群環(huán)境的過(guò)程_云其它
- 2022-04-16 C語(yǔ)言實(shí)現(xiàn)順序循環(huán)隊(duì)列實(shí)例_C 語(yǔ)言
- 2022-11-07 WPF使用DrawingContext實(shí)現(xiàn)繪制刻度條_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支