溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

laravel模型刪除和軟刪除是什么意思

發布時間:2021-03-10 15:56:03 來源:億速云 閱讀:319 作者:小新 欄目:編程語言

小編給大家分享一下laravel模型刪除和軟刪除是什么意思,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1、刪除模型

1.1 使用delete刪除模型

刪除模型很簡單,先獲取要刪除的模型實例,然后調用delete方法即可:

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

該方法返回true或false。

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、軟刪除實現

上述刪除方法都會將數據表記錄從數據庫刪除,此外Eloquent模型還支持軟刪除。

所謂軟刪除指的是數據表記錄并未真的從數據庫刪除,而是將表記錄的標識狀態標記為軟刪除,這樣在查詢的時候就可以加以過濾,讓對應表記錄看上去是被”刪除“了。Laravel中使用了一個日期字段作為標識狀態,這個日期字段可以自定義,這里我們使用deleted_at,如果對應模型被軟刪除,則deleted_at字段的值為刪除時間,否則該值為空。

要讓Eloquent模型支持軟刪除,還要做一些設置。首先在模型類中要使用SoftDeletestrait,該trait為軟刪除提供一系列相關方法,具體可參考源碼Illuminate\Database\Eloquent\SoftDeletes,此外還要設置$date屬性數組,將deleted_at置于其中:

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Post extends Model
{
    use SoftDeletes;
    //設置表名
    public $table = 'posts';
    //設置主鍵
    public $primaryKey = 'id';
    //設置日期時間格式
    public $dateFormat = 'U';
    protected $guarded = ['id','views','user_id','updated_at','created_at'];
    protected $dates = ['delete_at'];
}

然后對應的數據庫posts中添加deleted_at列,我們使用遷移來實現,先執行Artisan命令:

php artisan make:migration alter_posts_deleted_at --table=posts

然后編輯生成的PHP文件如下:

<?php
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class AlterPostsDeletedAt extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::table('posts', function (Blueprint $table) {
            $table->softDeletes();
        });
    }
    ...//其它方法
}

然后運行:

php artisan migrate

這樣posts中就有了deleted_at列。接下來,我們在控制器中編寫測試代碼:

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

那如果想要在查詢結果中包含軟刪除的記錄呢?可以使用SoftDeletes trait上的withTrashed方法:

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

有時候我們只想要查看被軟刪除的模型,這也有招,通過SoftDeletes上的onlyTrashed方法即可:

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

軟刪除恢復

有時候我們需要恢復被軟刪除的模型,可以使用SoftDeletes提供的restore方法:

恢復單個模型

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

有點問題,ID為6的已經被軟刪除了,Post::find(6) 是查不到數據的,

應該

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

恢復多個模型

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

恢復所有模型

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

恢復關聯查詢模型

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

強制刪除

如果模型配置了軟刪除但我們確實要刪除改模型對應數據庫表記錄,則可以使用SoftDeletes提供的forceDelete方法:

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

以上是“laravel模型刪除和軟刪除是什么意思”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女