1. 开发
1.1. 架构
Gorm使用可链接的API,*gorm.DB
是链的桥梁,对于每个链API,它将创建一个新的关系。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| db, err := gorm.Open("postgres", "user=gorm dbname=gorm sslmode=disable")
db = db.Where("name = ?", "jinzhu")
if SomeCondition { db = db.Where("age = ?", 20) } else { db = db.Where("age = ?", 30) } if YetAnotherCondition { db = db.Where("active = ?", 1) }
|
当我们开始执行任何操作时,GORM将基于当前的*gorm.DB
创建一个新的*gorm.Scope
实例
并且基于当前操作的类型,它将调用注册的creating
, updating
, querying
, deleting
或row_querying
回调来运行操作。
对于上面的例子,将调用querying,参考查询回调
1.2. 写插件
GORM本身由Callbacks
提供支持,因此您可以根据需要完全自定义GORM
1.2.1. 注册新的callback
1 2 3 4 5 6 7 8
| func updateCreated(scope *Scope) { if scope.HasColumn("Created") { scope.SetColumn("Created", NowFunc()) } }
db.Callback().Create().Register("update_created_at", updateCreated)
|
1.2.2. 删除现有的callback
1 2
| db.Callback().Create().Remove("gorm:create")
|
1.2.3. 替换现有的callback
1 2
| db.Callback().Create().Replace("gorm:create", newCreateFunction)
|
1.2.4. 注册callback顺序
1 2 3 4 5 6
| db.Callback().Create().Before("gorm:create").Register("update_created_at", updateCreated) db.Callback().Create().After("gorm:create").Register("update_created_at", updateCreated) db.Callback().Query().After("gorm:query").Register("my_plugin:after_query", afterQuery) db.Callback().Delete().After("gorm:delete").Register("my_plugin:after_delete", afterDelete) db.Callback().Update().Before("gorm:update").Register("my_plugin:before_update", beforeUpdate) db.Callback().Create().Before("gorm:create").After("gorm:before_create").Register("my_plugin:before_create", beforeCreate)
|
1.2.5. 预定义回调
GORM定义了回调以执行其CRUD操作,在开始编写插件之前检查它们。
- Create callbacks
- Update callbacks
- Query callbacks
- Delete callbacks
- Row Query callbacks Row Query callbacks将在运行Row或Rows时被调用,默认情况下没有注册的回调,你可以注册一个新的回调:
1 2 3 4 5
| func updateTableName(scope *gorm.Scope) { scope.Search.Table(scope.TableName() + "_draft") }
db.Callback().RowQuery().Register("publish:update_table_name", updateTableName)
|