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

如何用ThinkPHP里的模型方式对数据进行假删除

在我们实际使用ThinkPHP的工作和项目开发中,对数据库频繁的操作,删除数据,会导致用户体验性很差的问题,利用模型的软删除方法就是把数据加上删除标记,而不是真正的把数据从数据库中的删除,这样会非常方便的对数据库进行修复操作,同时也会大大提升用户的体验。 要使用软删除功能,首先需要引入一个类SoftDelete类,软删除即增加时间戳的方式对数据进行假删除。

增加类的写法:use traitsmodelSoftDelete;

然后需要在Model文件的创建类里使用软删除,使用软删除的写法是:use SoftDelete; protected $deleteTime = 'delete_time'; 完整的引用类和使用软删除方法如下图:

其中deleteTime属性用于定义你的软删除标记字段,ThinkPHP5的软删除功能使用时间戳类型(数据表默认值为NULL);即把delete_time字段增加到数据库对应的表中,默认值为NULL,软删除即增加当时的时间戳改变了NULL值,那么就是相当于假删除了。

定义好上面的模型后,我们就可以使用软删除了,如下图,是软删除的套路

但是有一种数据库删除的方式要注意不会触发软删除Data::where('id','=',1)->delete();在这里你会直接把id=1进行真删除,因为这里的数据删除写法没有使用模型删除,单纯的Data删除法是可以直接删除原数据库里的数据,要注意哟!

如何用ThinkPHP里的模型方式对数据进行假删除(软删除)

https://www.qwzyj.com/thread-168-1-1.html

(出处: 全网资源菌)

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

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券