当前位置: 首页 > 文档资料 > GORM 1.0 中文文档 >

6. Callbacks

优质
小牛编辑
150浏览
2023-12-01

您可以将回调方法定义为模型结构的指针,在创建,更新,查询,删除时将被调用,如果任何回调返回错误,gorm将停止未来操作并回滚所有更改。

创建对象

创建过程中可用的回调

  1. // begin transaction 开始事物
  2. BeforeSave
  3. BeforeCreate
  4. // save before associations 保存前关联
  5. // update timestamp `CreatedAt`, `UpdatedAt` 更新`CreatedAt`, `UpdatedAt`时间戳
  6. // save self 保存自己
  7. // reload fields that have default value and its value is blank 重新加载具有默认值且其值为空的字段
  8. // save after associations 保存后关联
  9. AfterCreate
  10. AfterSave
  11. // commit or rollback transaction 提交或回滚事务

更新对象

更新过程中可用的回调

  1. // begin transaction 开始事物
  2. BeforeSave
  3. BeforeUpdate
  4. // save before associations 保存前关联
  5. // update timestamp `UpdatedAt` 更新`UpdatedAt`时间戳
  6. // save self 保存自己
  7. // save after associations 保存后关联
  8. AfterUpdate
  9. AfterSave
  10. // commit or rollback transaction 提交或回滚事务

删除对象

删除过程中可用的回调

  1. // begin transaction 开始事物
  2. BeforeDelete
  3. // delete self 删除自己
  4. AfterDelete
  5. // commit or rollback transaction 提交或回滚事务

查询对象 {#querying-an-object}

查询过程中可用的回调

  1. // load data from database 从数据库加载数据
  2. // Preloading (edger loading) 预加载(加载)
  3. AfterFind

回调示例

  1. func (u *User) BeforeUpdate() (err error) {
  2. if u.readonly() {
  3. err = errors.New("read only user")
  4. }
  5. return
  6. }
  7. // 如果用户ID大于1000,则回滚插入
  8. func (u *User) AfterCreate() (err error) {
  9. if (u.Id > 1000) {
  10. err = errors.New("user id is already greater than 1000")
  11. }
  12. return
  13. }

gorm中的保存/删除操作正在事务中运行,因此在该事务中所做的更改不可见,除非提交。 如果要在回调中使用这些更改,则需要在同一事务中运行SQL。 所以你需要传递当前事务到回调,像这样:

  1. func (u *User) AfterCreate(tx *gorm.DB) (err error) {
  2. tx.Model(u).Update("role", "admin")
  3. return
  4. }
  1. func (u *User) AfterCreate(scope *gorm.Scope) (err error) {
  2. scope.DB().Model(u).Update("role", "admin")
  3. return
  4. }

最后更新:

类似资料

  • 回调函数使用 回调函数是一个函数的合集,会在训练的阶段中所使用。你可以使用回调函数来查看训练模型的内在状态和统计。你可以传递一个列表的回调函数(作为 callbacks 关键字参数)到 Sequential 或 Model 类型的 .fit() 方法。在训练时,相应的回调函数的方法就会被在各自的阶段被调用。 [source] Callback keras.callbacks.callbacks.C

  • Callbacks Definition for source argument beforeKeyDown use case Callbacks This page shows usage of some callbacks available in Handsontable. If you require a new callback to be added, please open an i

  • allows applications to maintain threadlocal-like state that follows execution as it moves to other execution contexts. The motivating examples are to eliminate the need for explicit async_callback wra

  • 问题内容: 我想为成功/错误响应显示不同的通知栏,我将两个callBack传递给我的react组件中的redux异步操作,如下所示: 其中asyncAction看起来像这样: 是否认为这与模式相反?换句话说,通知栏是否应根据状态更改而不是根据回调打开? 问题答案: 模式本身很好。如果这是组件本地的通知,请随时避免通过Redux对其进行接线。 也就是说,回调是完全不必要的, 因为您已经在返回prom

  • 问题内容: 我有一些要更新的旧Node.js代码。在此过程中,我正在设计新模块以与旧代码一起使用。我发现现在,与我最初写这篇文章时相反,我更多地依赖使用ES6 Promise,而不是回调。所以现在我混合了一些函数,这些函数返回Promise和一些采用回调-这很乏味。我认为最终应该重构使用诺言。但是在那之前… 在什么情况下首选promise和回调在哪里? 在某种情况下,回调能比承诺更好地处理吗,反之

  • callbackScope: Object 用于所有回调的范围(onStart,onUpdate,onComplete等)。范围是“this”在任何回调中引用的内容。旧的回调特定范围属性(onStartScope,onUpdateScope,onCompleteScope,onReverseComplete等)已弃用但仍然有效。 callbackScope适用于TweenMaxTweenLite