欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

laravel中軟刪除的實(shí)例分析

這篇文章主要介紹“l(fā)aravel中軟刪除的實(shí)例分析”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“l(fā)aravel中軟刪除的實(shí)例分析”文章能幫助大家解決問題。

創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的鐵山港網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

在laravel中,軟刪除指的是數(shù)據(jù)表記錄并未真的從數(shù)據(jù)庫中刪除,而是將表記錄的表示狀態(tài)標(biāo)記為軟刪除,這樣在查詢時(shí)就可以進(jìn)行過濾,讓對(duì)應(yīng)表記錄看上去像是被“刪除”了。

本文操作環(huán)境:Windows10系統(tǒng)、Laravel6版、Dell G3電腦。

laravel中軟刪除的原理是什么

1、刪除模型

1.1 使用delete刪除模型

刪除模型很簡(jiǎn)單,先獲取要?jiǎng)h除的模型實(shí)例,然后調(diào)用delete方法即可:

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

該方法返回truefalse。

1.2 使用destroy刪除模型

當(dāng)然如果已知要?jiǎng)h除的模型id的話,可以用更簡(jiǎn)單的方法destroy直接刪除:

$deleted = Post::destroy(5);

你也可以一次傳入多個(gè)模型id刪除多個(gè)模型:

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

調(diào)用destroy方法返回被刪除的記錄數(shù)。

1.3 使用查詢構(gòu)建器刪除模型

既然前面提到Eloquent模型本身就是查詢構(gòu)建器,也可以使用查詢構(gòu)建器風(fēng)格刪除模型,比如我們要?jiǎng)h除所有瀏覽數(shù)為0的文章,可以使用如下方式:

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

返回結(jié)果為被刪除的文章數(shù)。

2、軟刪除及其相關(guān)實(shí)現(xiàn)

2.1 軟刪除實(shí)現(xiàn)

上述刪除方法都會(huì)將數(shù)據(jù)表記錄從數(shù)據(jù)庫刪除,此外Eloquent模型還支持軟刪除。

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

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

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;

class Post extends Model
{
    use SoftDeletes;

    //設(shè)置表名
    public $table = 'posts';

    //設(shè)置主鍵
    public $primaryKey = 'id';

    //設(shè)置日期時(shí)間格式
    public $dateFormat = 'U';

    protected $guarded = ['id','views','user_id','updated_at','created_at'];

    protected $dates = ['delete_at'];
}

然后對(duì)應(yīng)的數(shù)據(jù)庫posts中添加deleted_at列,我們使用遷移來實(shí)現(xiàn),先執(zhí)行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();
        });
    }

    ...//其它方法
}

然后運(yùn)行:

php artisan migrate

這樣posts中就有了deleted_at列。接下來,我們?cè)诳刂破髦芯帉憸y(cè)試代碼:

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

在瀏覽器中訪問http://laravel.app:8000/test

當(dāng)我們?cè)俅瓮ㄟ^下面這段代碼獲取所有文章:

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

已經(jīng)看不到id為6的文章的身影了。

2.2 查詢結(jié)果包含軟刪除模型

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

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

id為6的文章又出現(xiàn)在了查詢結(jié)果中。有時(shí)候我們只想要查看被軟刪除的模型,這也有招,通過SoftDeletes上的onlyTrashed方法即可:

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

2.3 軟刪除恢復(fù)

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

恢復(fù)單個(gè)模型

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

恢復(fù)多個(gè)模型

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

恢復(fù)所有模型

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

恢復(fù)關(guān)聯(lián)查詢模型

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

2.4 強(qiáng)制刪除

如果模型配置了軟刪除但我們確實(shí)要?jiǎng)h除改模型對(duì)應(yīng)數(shù)據(jù)庫表記錄,則可以使用SoftDeletes提供的forceDelete方法:

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

關(guān)于“l(fā)aravel中軟刪除的實(shí)例分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

網(wǎng)站名稱:laravel中軟刪除的實(shí)例分析
本文地址:http://chinadenli.net/article24/gopsje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、網(wǎng)站排名、網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站建設(shè)、網(wǎng)站收錄、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化