Home / PostsPost
Golang GORM 软删除和硬删除
嘟噜聪2020/08/09 16:48:47
[Golang]
[gorm]
6403人已阅
简介 我们创建数据表时一般会增加一个`deleted_at`的字段,主要用来标识这条记录是否删除,及删除的时间。.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)
上一篇:如何关闭支付宝花呗