软删除就是逻辑删除,数据保留单标记上删除状态,一般我们会用删除时间来作为标记,这样标记状态有了,删除时间也有了
用Laravel 自带的 Eloquent ORM 来实现软删除。
首先在数据迁移文件中添加删除时间字段
./database/migrations/2014_10_12_000000_create_users_table.php
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->string('email')->unique();
$table->timestamp('email_verified_at')->nullable();
$table->string('password');
$table->rememberToken();
$table->timestamps();
$table->softDeletes()->comment('删除时间');// 默认添加 deleted_at 字段
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('users');
}
};
执行 php artisan migrate
运行迁移文件
修改对应的数据模型
./app/Models/User.php
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
use SoftDeletes;// 开启软删除
protected $guarded = [];// 不可以注入的字段数据,使用create方法才有效
}
软删除方法
直接调用delete()
方法或者destroy()
方法即可
User::destroy($id);
这时候查询的数据自动添加过滤条件 deleted_at = NULL
恢复删除
User::onlyTrashed()->where('id', $id)->restore();
永久删除
直接删除数据
User::forceDeleted($id);
查询包含已删除的数据
使用 withTrashed()
可以查询出包含已删除的数据
User::withTrashed()->get();
只查询已删除的数据
使用 onlyTrashed()
可以只查询出已删除的数据
User::onlyTrashed()->get();
到此这篇关于PHP Laravel软删除的实现方法介绍的文章就介绍到这了,更多相关PHP Laravel软删除内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:PHP Laravel软删除的实现方法介绍


基础教程推荐
猜你喜欢
- php+mysql开发的最简单在线题库(在线做题系统)完整案例 2023-01-04
- php如何获取当前日期和星期 2024-12-06
- Laravel 解决composer相关操作提示php相关异常的问题 2023-03-08
- Laravel修改验证提示信息为中文的示例 2023-03-08
- PHP基于反射机制实现自动依赖注入的方法详解 2022-10-02
- PHP laravel使用自定义邮件类实现发送邮件 2023-07-03
- php去除deprecated的实例方法 2022-09-02
- PHP字符串函数系列之nl2br(),在字符串中的每个新行 (\n) 之前插入 HTML 换行符br 2024-03-28
- php生成短网址/短链接原理和用法实例分析 2023-04-20
- PHP采用get获取url汉字出现乱码的解决方法 2024-03-28