Home / PostsPost

Golang GORM 软删除和硬删除

嘟噜聪2020/08/09 16:48:47 [Golang] [gorm] 315人已阅

简介 我们创建数据表时一般会增加一个`deleted_at`的字段,主要用来标识这条记录是否删除,及删除的时间。![](http://source.qiniu.cnd.nsini.com/image

我们创建数据表时一般会增加一个deleted_at的字段,主要用来标识这条记录是否删除,及删除的时间。

下面建一张表的结构体

type SysUser struct {
	Id        int64      `gorm:"column:id;rimary_key"`
	LoginName string     `gorm:"column:login_name;index;unique;size:32"`
	Password  string     `gorm:"column:password;null"`
	LastLogin *time.Time `gorm:"column:last_login;null"`
	Locked    bool       `gorm:"column:locked;null"`
	CreatedAt time.Time  `gorm:"column:created_at"`
	UpdatedAt time.Time  `gorm:"column:updated_at"`
	DeletedAt *time.Time `gorm:"column:deleted_at;null"`
}

创建一张系统用户表,DeletedAt字段可以为空,类型是*time.Time可以是nil。

然后生成表:

var db *gorm.DB
// 连接数据库 省略

// 创建数据库表
db.CreateTable(&SysUser{}).Error

软删除

软删除执行的是UPDATE语句,将deleted_at字段设置一个时间就行,gorm 默认就是软删,已经帮我们做好了,像下面这样直接使用就行了。

db.Where("id = ?", 1).Delete(&SysUser{}).Error

执行的SQL:

UPDATE `sys_user` SET `deleted_at` = '2020-08-09 14:32:11' WHERE `id` IN ('1');

硬删除

硬删除是奖数据真实的删除,使用的是Unscoped()方法,执行的是DELETE语句:

db.Where("id = ?", 1).Unscoped().Delete(&SysUser{}).Error

执行的SQL:

DELETE FROM `sys_user` WHERE `id` IN ('1');

很赞哦! (1)

文章评论

标签

站点信息

  • 微信公众号