删除一条记录
删除一条记录时,删除对象需要指定主键,否则会触发 批量删除,例如:
// Email 的 ID 是 `10` |
根据主键删除
GORM 允许通过主键(可以是复合主键)和内联条件来删除对象,它可以使用数字(如以下例子。也可以使用字符串——译者注)。查看 查询-内联条件(Query Inline Conditions) 了解详情。
db.Delete(&User{}, 10) |
钩子函数
对于删除操作,GORM 支持 BeforeDelete
、AfterDelete
Hook,在删除记录时会调用这些方法,查看 Hook 获取详情
func (u *User) BeforeDelete(tx *gorm.DB) (err error) { |
批量删除
如果指定的值不包括主属性,那么 GORM 会执行批量删除,它将删除所有匹配的记录
db.Where("email LIKE ?", "%jinzhu%").Delete(&Email{}) |
可以将一个主键切片传递给Delete
方法,以便更高效的删除数据量大的记录
var users = []User{{ID: 1}, {ID: 2}, {ID: 3}} |
阻止全局删除
当你试图执行不带任何条件的批量删除时,GORM将不会运行并返回ErrMissingWhereClause
错误
如果一定要这么做,你必须添加一些条件,或者使用原生SQL,或者开启AllowGlobalUpdate
模式,如下例:
db.Delete(&User{}).Error // gorm.ErrMissingWhereClause |
返回删除行的数据
返回被删除的数据,仅当数据库支持回写功能时才能正常运行,如下例:
// 回写所有的列 |
软删除
如果你的模型包含了 gorm.DeletedAt
字段(该字段也被包含在gorm.Model
中),那么该模型将会自动获得软删除的能力!
当调用Delete
时,GORM并不会从数据库中删除该记录,而是将该记录的DeleteAt
设置为当前时间,而后的一般查询方法将无法查找到此条记录。
// user's ID is `111` |
如果你并不想嵌套gorm.Model
,你也可以像下方例子那样开启软删除特性:
type User struct { |
查找被软删除的记录
你可以使用Unscoped
来查询到被软删除的记录
db.Unscoped().Where("age = 20").Find(&users) |
永久删除
你可以使用 Unscoped
来永久删除匹配的记录
db.Unscoped().Delete(&order) |
删除标志
默认情况下,gorm.Model
使用*time.Time
作为DeletedAt
的字段类型,不过软删除插件gorm.io/plugin/soft_delete
同时也提供其他的数据格式支持
提示 当使用DeletedAt创建唯一复合索引时,你必须使用其他的数据类型,例如通过
gorm.io/plugin/soft_delete
插件将字段类型定义为unix时间戳等等
import "gorm.io/plugin/soft_delete"
type User struct {
ID uint
Name string `gorm:"uniqueIndex:udx_name"`
DeletedAt soft_delete.DeletedAt `gorm:"uniqueIndex:udx_name"`
}
Unix 时间戳
使用unix时间戳作为删除标志
import "gorm.io/plugin/soft_delete" |
你同样可以指定使用毫秒 milli
或纳秒 nano
作为值,如下例:
type User struct { |
使用 1
/ 0
作为 删除标志
import "gorm.io/plugin/soft_delete" |
混合模式
混合模式可以使用 0
,1
或者unix时间戳来标记数据是否被软删除,并同时可以保存被删除时间
type User struct { |