软删除
最后更新于:2022-04-02 01:52:07
## 软删除
在实际项目中,对数据频繁使用删除操作会导致性能问题,软删除的作用就是把数据加上删除标记,而不是真正的删除,同时也便于需要的时候进行数据的恢复。
要使用软删除功能,需要引入`SoftDelete` trait,例如`User`模型按照下面的定义就可以使用软删除功能:
~~~
`V5.1.9+`版本开始,可以支持`defaultSoftDelete`属性来定义软删除字段的默认值,在此之前的版本,软删除字段的默认值必须为`null`。
~~~
可以用类型转换指定软删除字段的类型,建议数据表的所有时间字段统一一种类型。
定义好模型后,我们就可以使用:
~~~
// 软删除
User::destroy(1);
// 真实删除
User::destroy(1,true);
$user = User::get(1);
// 软删除
$user->delete();
// 真实删除
$user->delete(true);
~~~
默认情况下查询的数据不包含软删除数据,如果需要包含软删除的数据,可以使用下面的方式查询:
~~~
User::withTrashed()->find();
User::withTrashed()->select();
~~~
如果仅仅需要查询软删除的数据,可以使用:
~~~
User::onlyTrashed()->find();
User::onlyTrashed()->select();
~~~
恢复被软删除的数据
~~~php
$user = User::onlyTrashed()->find(1);
$user->restore();
~~~
>[danger] 软删除仅对模型的删除方法有效,如果直接使用数据库的删除方法则无效,例如下面的方式无效(将不会执行任何操作)。
~~~
$user = new User;
$user->where('id',1)->delete();
~~~
';