在 GORM 中,可以通过给模型的 DeletedAt 字段指定当前时间戳来实现软删除功能。具体操作如下:
- 定义 Model
在定义 Model 时,需要在表结构中加入 DeletedAt 字段。
type User struct {
gorm.Model
Name string
Age int
Email string `gorm:"uniqueIndex"`
DeletedAt *time.Time // 添加 DeletedAt 字段
}
- 启用软删除
db := gorm.Open("mysql", "dsn")
db = db.Debug().Set("gorm:delete_option", "OPTION (OPTIMIZE FOR UNKNOWN)").Model(&User{}).Where("deleted_at is null") // 启用软删除
- 执行软删除
使用 Delete 方法进行软删除时,可以自动将 DeletedAt 字段设为当前时间戳。具体代码如下:
// 软删除一条记录,并设置 deleted_at 为当前时间戳
user := User{ID: 1}
db.Delete(&user)
// 查询所有未被软删除的记录(DeletedAt IS NULL)
var users []User
db.Find(&users)
注意:如果你想手动设置 DeletedAt 的值为当前时间戳,可以直接对字段赋值。例如:
now := time.Now()
user.DeletedAt = &now // 设置 DeletedAt 为当前时间戳
db.Save(&user) // 保存到数据库中