ZBLOG

golang gorm通过deleted_at字段来删除条目,如何实现?

使用 Gorm 操作数据库时,可以通过 soft delete 功能实现逻辑删除。这个功能就是在数据库中添加一个名为 deleted_at 的字段,在删除数据时只是将该字段标记为当前时间戳,而不是真正的物理删除。具体操作如下:

  1. 定义 Model

在定义 Model 时,需要在表结构中加入 DeletedAt 字段。

type User struct {
    gorm.Model
    Name      string
    Age       int
    Email     string `gorm:"uniqueIndex"`
    DeletedAt *time.Time // 添加 DeletedAt 字段
}
  1. 启用软删除
db := gorm.Open("mysql", "dsn")
db = db.Debug().Set("gorm:delete_option", "OPTION (OPTIMIZE FOR UNKNOWN)").Model(&User{}).Where("deleted_at is null") // 启用软删除
  1. 执行软删除

使用 Delete 方法进行软删除:

// 软删除一条记录
user := User{ID: 1}
db.Delete(&user)

// 查询所有未被软删除的记录(DeletedAt IS NULL)
var users []User
db.Find(&users)

查询结果将不包含已经被软删除的记录。

注意:如果你要查询已经被软删除的记录,可以使用 Unscoped 方法进行恢复。例如:

// 查询所有已被软删除的记录(DeletedAt IS NOT NULL)
var deletedUsers []User
db.Unscoped().Find(&deletedUsers)

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=2546

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?