Go?GORM?事務(wù)詳細(xì)介紹
禁用默認(rèn)事務(wù)
為了確保數(shù)據(jù)一致性,GORM 會(huì)在事務(wù)里執(zhí)行寫(xiě)入操作(創(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 { // 再?lài)Z叨一下,事務(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
到此這篇關(guān)于Go GORM 事務(wù)詳細(xì)介紹的文章就介紹到這了,更多相關(guān)Go GORM 事務(wù) 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解如何利用GORM實(shí)現(xiàn)MySQL事務(wù)
- golang操作連接數(shù)據(jù)庫(kù)實(shí)現(xiàn)mysql事務(wù)示例
- 關(guān)于MySQL與Golan分布式事務(wù)經(jīng)典的七種解決方案
- golang實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)事務(wù)的提交與回滾
- golang如何優(yōu)雅的編寫(xiě)事務(wù)代碼示例
- golang?db事務(wù)的統(tǒng)一封裝的實(shí)現(xiàn)
- 深入分析Go?實(shí)現(xiàn)?MySQL?數(shù)據(jù)庫(kù)事務(wù)
相關(guān)文章
Go?語(yǔ)言使用goroutine運(yùn)行閉包踩坑分析
這篇文章主要介紹了Go?語(yǔ)言使用goroutine運(yùn)行閉包踩坑解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11gin 獲取post請(qǐng)求的json body操作
這篇文章主要介紹了gin 獲取post請(qǐng)求的json body操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03go redis實(shí)現(xiàn)滑動(dòng)窗口限流的方式(redis版)
這篇文章主要介紹了go redis實(shí)現(xiàn)滑動(dòng)窗口限流的方式(redis版),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12初學(xué)Go必備的vscode插件及最常用快捷鍵和代碼自動(dòng)補(bǔ)全
這篇文章主要給大家介紹了關(guān)于初學(xué)vscode寫(xiě)Go必備的vscode插件及最常用快捷鍵和代碼自動(dòng)補(bǔ)全的相關(guān)資料,由于vscode是開(kāi)源免費(fèi)的,而且開(kāi)發(fā)支持vscode的插件相對(duì)比較容易,更新速度也很快,需要的朋友可以參考下2023-07-07go語(yǔ)言中GOPATH GOROOT的作用和設(shè)置方式
這篇文章主要介紹了go語(yǔ)言中GOPATH GOROOT的作用和設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-05-05Go語(yǔ)言對(duì)JSON數(shù)據(jù)進(jìn)行序列化和反序列化
這篇文章介紹了Go語(yǔ)言對(duì)JSON數(shù)據(jù)進(jìn)行序列化和反序列化的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07