Laravel 模型如何实现软删除?请简要说明步骤

请尝试在评论区里写下答案(如不能清楚表述,那么你可能没真正理解)。欢迎参与,为下一次求职做准备。

如题

摈弃世俗浮躁,追求技术精湛
Summer
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 4
Lucifer103
  1. 在模型中添加 Illuminate\Database\Eloquent\SoftDeletes trait
  2. 在数据表中增加 deleted_at 字段

不知道这个问题的本意就是这么简单还是想问 Laravel 的底层逻辑 :wink:

1个月前 评论

我用的软删除不是时间戳,比如说 status=-1表示软删除,这个要怎么做?

1个月前 评论
godruoyi

软删除本质上是为查询的每一个 SQL 加上相应的过滤条件实现的;如加了软删除的模型,在每一次查询的时候,系统会自动添加 and deleted_at is null

在使用软删除时,需要为模型引入 SoftDelete 这个 trait,在这个 trait 里,通过添加全局 scope 的方式为这个模型添加类似这样的查询条件: whereNotNull('deleted_at')

1个月前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!