您好,登錄后才能下訂單哦!
這篇文章主要介紹了golang gorm的Callbacks事務回滾對象怎么創建的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇golang gorm的Callbacks事務回滾對象怎么創建文章都會有所收獲,下面我們一起來看看吧。
您可以將回調方法定義為模型結構的指針,在創建,更新,查詢,刪除時將被調用,如果任何回調返回錯誤,gorm將停止未來操作并回滾所有更改。
創建過程中可用的回調
// begin transaction 開始事物 BeforeSave BeforeCreate // save before associations 保存前關聯 // update timestamp `CreatedAt`, `UpdatedAt` 更新`CreatedAt`, `UpdatedAt`時間戳 // save self 保存自己 // reload fields that have default value and its value is blank 重新加載具有默認值且其值為空的字段 // save after associations 保存后關聯 AfterCreate AfterSave // commit or rollback transaction 提交或回滾事務
更新過程中可用的回調
// begin transaction 開始事物 BeforeSave BeforeUpdate // save before associations 保存前關聯 // update timestamp `UpdatedAt` 更新`UpdatedAt`時間戳 // save self 保存自己 // save after associations 保存后關聯 AfterUpdate AfterSave // commit or rollback transaction 提交或回滾事務
刪除過程中可用的回調
// begin transaction 開始事物 BeforeDelete // delete self 刪除自己 AfterDelete // commit or rollback transaction 提交或回滾事務
查詢過程中可用的回調
// load data from database 從數據庫加載數據 // Preloading (edger loading) 預加載(加載) AfterFind
func (u *User) BeforeUpdate() (err error) { if u.readonly() { err = errors.New("read only user") } return } // 如果用戶ID大于1000,則回滾插入 func (u *User) AfterCreate() (err error) { if (u.Id > 1000) { err = errors.New("user id is already greater than 1000") } return }
gorm中的保存/刪除操作正在事務中運行,因此在該事務中所做的更改不可見,除非提交。 如果要在回調中使用這些更改,則需要在同一事務中運行SQL。 所以你需要傳遞當前事務到回調,像這樣:
func (u *User) AfterCreate(tx *gorm.DB) (err error) { tx.Model(u).Update("role", "admin") return } func (u *User) AfterCreate(scope *gorm.Scope) (err error) { scope.DB().Model(u).Update("role", "admin") return }
關于“golang gorm的Callbacks事務回滾對象怎么創建”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“golang gorm的Callbacks事務回滾對象怎么創建”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。