首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ThinkPHP5开发连载五十二之模型-软删除

上一篇文章讲解“模型-只读字段”,本篇文章讲解“模型-软删除”。

在实际项目中,对数据频繁使用删除操作会导致性能问题,软删除的作用就是把数据加上删除标记,而不是真正的删除,同时也便于需要的时候进行数据的恢复。

要使用软删除功能,需要引入SoftDelete trait,例如User模型按照下面的定义就可以使用软删除功能:

deleteTime属性用于定义你的软删除标记字段,ThinkPHP5的软删除功能使用时间戳类型(数据表默认值为Null),用于记录数据的删除时间。

注意:

1. 可以用类型转换指定软删除字段的类型,建议数据表的所有时间字段统一一种类型。

1. 软删除

新建User模型,并设置软删除

在user表中添加delete_time字段

新建Index控制器,并创建softDelete方法,分别用destroy与delete方法。

浏览器访问后,查看数据库

软删除前:

软删除后:

注意:

1. destroy与delete的软删除与真是删除,可详见上方代码。

2. 软删除后的查询

1)查询结果中包含软删除数据

默认情况下查询的数据不包含软删除数据,如果需要包含软删除的数据,可以使用withTrashed查询。

Index控制器,新建selectData方法,正常查询所有数据

浏览器访问

修改Index控制器中selectDate方法,查询包含软删除的数据

浏览器访问:

注意:

1. 当用find查询单条软删除数据时,不加withTrashed返回NULL。

2)仅查询软删除数据

如果仅仅需要查询软删除的数据,可以使用:

在Index控制器中,新建softData方法,仅查询软删除数据

浏览器访问(为了更清楚,可以做几条软删除数据)

3. 恢复被软删除的数据

恢复被软删除的数据

在Index控制器中,新建restoreData方法,恢复被软删除的数据

浏览器访问后,查询数据库

恢复前:

恢复后:

注意:

1. 软删除仅对模型的删除方法有效,如果直接使用数据库的删除方法则无效。

ThinkPHP5连载为卓象程序员原创,转载请联系卓象程序员

关注卓象程序员,定期发布技术文章

下一篇讲解“模型-类型转换”

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180920A1241D00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券