ZBLOG

gorm 为deleted_at设置当前时间戳

在 GORM 中,可以通过给模型的 DeletedAt 字段指定当前时间戳来实现软删除功能。具体操作如下:

  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 方法进行软删除时,可以自动将 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)        // 保存到数据库中

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

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

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

联系我们

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

微信号:3007537140

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

关注我们
x

注册

已经有帐号?