千家信息网

laravel中软删除的实例分析

发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,这篇文章主要介绍"laravel中软删除的实例分析"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"laravel中软删除的实例分析"文章能帮助大家解决问题。在l
千家信息网最后更新 2025年02月05日laravel中软删除的实例分析

这篇文章主要介绍"laravel中软删除的实例分析"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"laravel中软删除的实例分析"文章能帮助大家解决问题。

在laravel中,软删除指的是数据表记录并未真的从数据库中删除,而是将表记录的表示状态标记为软删除,这样在查询时就可以进行过滤,让对应表记录看上去像是被"删除"了。

本文操作环境:Windows10系统、Laravel6版、Dell G3电脑。

laravel中软删除的原理是什么

1、删除模型

1.1 使用delete删除模型

删除模型很简单,先获取要删除的模型实例,然后调用delete方法即可:

$post = Post::find(5);if($post->delete()){    echo '删除文章成功!';}else{    echo '删除文章失败!';}

该方法返回truefalse

1.2 使用destroy删除模型

当然如果已知要删除的模型id的话,可以用更简单的方法destroy直接删除:

$deleted = Post::destroy(5);

你也可以一次传入多个模型id删除多个模型:

$deleted = Post::destroy([1,2,3,4,5]);

调用destroy方法返回被删除的记录数。

1.3 使用查询构建器删除模型

既然前面提到Eloquent模型本身就是查询构建器,也可以使用查询构建器风格删除模型,比如我们要删除所有浏览数为0的文章,可以使用如下方式:

$deleted = Models\Post::where('views', 0)->delete();

返回结果为被删除的文章数。

2、软删除及其相关实现

2.1 软删除实现

上述删除方法都会将数据表记录从数据库删除,此外Eloquent模型还支持软删除。

所谓软删除指的是数据表记录并未真的从数据库删除,而是将表记录的标识状态标记为软删除,这样在查询的时候就可以加以过滤,让对应表记录看上去是被"删除"了。Laravel中使用了一个日期字段作为标识状态,这个日期字段可以自定义,这里我们使用deleted_at,如果对应模型被软删除,则deleted_at字段的值为删除时间,否则该值为空。

要让Eloquent模型支持软删除,还要做一些设置。首先在模型类中要使用SoftDeletestrait,该trait为软删除提供一系列相关方法,具体可参考源码Illuminate\Database\Eloquent\SoftDeletes,此外还要设置$date属性数组,将deleted_at置于其中:

然后对应的数据库posts中添加deleted_at列,我们使用迁移来实现,先执行Artisan命令:

php artisan make:migration alter_posts_deleted_at --table=posts

然后编辑生成的PHP文件如下:

softDeletes();        });    }    ...//其它方法}

然后运行:

php artisan migrate

这样posts中就有了deleted_at列。接下来,我们在控制器中编写测试代码:

$post = Post::find(6);$post->delete();if($post->trashed()){    echo '软删除成功!';    dd($post);}else{    echo '软删除失败!';}

在浏览器中访问http://laravel.app:8000/test

当我们再次通过下面这段代码获取所有文章:

$posts = Post::all();dd($posts);

已经看不到id为6的文章的身影了。

2.2 查询结果包含软删除模型

那如果想要在查询结果中包含软删除的记录呢?可以使用SoftDeletes trait上的withTrashed方法:

$posts = Post::withTrashed()->get();dd($posts);

id为6的文章又出现在了查询结果中。有时候我们只想要查看被软删除的模型,这也有招,通过SoftDeletes上的onlyTrashed方法即可:

$posts = Post::onlyTrashed()->get();dd($posts);

2.3 软删除恢复

有时候我们需要恢复被软删除的模型,可以使用SoftDeletes提供的restore方法:

恢复单个模型

$post = Post::find(6);$post->restore();

恢复多个模型

Post::withTrashed()->where('id','>',1)->restore();

恢复所有模型

Post::withTrashed()->restore();

恢复关联查询模型

$post = Post::find(6);$post->history()->restore();

2.4 强制删除

如果模型配置了软删除但我们确实要删除改模型对应数据库表记录,则可以使用SoftDeletes提供的forceDelete方法:

$post = Post::find(6);$post->forceDelete();

关于"laravel中软删除的实例分析"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

模型 方法 查询 数据 文章 数据库 实例 结果 实例分析 分析 多个 字段 数据表 日期 状态 知识 成功 代码 时间 有时候 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 服务器安装win10后怎么样 浙江中兴网络技术有限公司 服务器为什么要租用 上海单据外贸软件开发 东莞自主可控软件开发价钱 北京冬奥5g网络安全吗 小米路由器ftp服务器 电子商务系统网络安全设置 汉口学院学生网络安全守则 小学生网络安全宣传视频制作 两设备之间如何传数据库 深信服长沙软件开发待遇 软件开发工资计入研发费多少 台湾生鲜信息软件开发 机读数据库的特点 网络技术类专业是艺术类专业吗 北京联想服务器维修调试哪家便宜 杭州金融软件开发公司有哪些 网络安全小黑板怎么看有害信息 网络安全cisa课程 软件开发有限公司组织架构 数据库技术与应用课本的答案 厦门市5g光纤服务器多少钱一台 达州网络技术哪家强 数据库定义列规则 为什么网络无法连接到服务器电视 服务器ssd硬盘 iops 高景网络技术 上海物业 电脑服务器正在运行中怎么回事 软件开发的实施办法
0