Home / PostsPost
Golang GORM 软删除和硬删除
嘟噜聪2020/08/09 16:48:47 [Golang] [gorm] 6317人已阅
简介 我们创建数据表时一般会增加一个`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');
很赞哦! (3)
上一篇:如何关闭支付宝花呗