站長資訊網
        最全最豐富的資訊網站

        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 = ModelsPost::where('views', 0)->delete();

        返回結果為被刪除的文章數。

        2、軟刪除及其相關實現

        2.1 軟刪除實現

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

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

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

        <?php  namespace AppModels;  use IlluminateDatabaseEloquentModel; use IlluminateDatabaseEloquentSoftDeletes;  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 IlluminateDatabaseSchemaBlueprint; use IlluminateDatabaseMigrationsMigration;  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 '軟刪除失敗!'; }

        在瀏覽器中訪問http://laravel.app:8000/test,頁面輸出如下:

        laravel中軟刪除的原理是什么

        當我們再次通過下面這段代碼獲取所有文章:

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

        已經看不到id為6的文章的身影了。

        2.2 查詢結果包含軟刪除模型

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

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

        執行之后頁面顯示如下:

        laravel中軟刪除的原理是什么

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

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

        執行后頁面顯示結果如下:

        laravel中軟刪除的原理是什么

        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();

        查看數據表可以發現id=6的表記錄已經被刪除,不復存在:

        laravel中軟刪除的原理是什么

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲第一区精品日韩在线播放| 四虎影视国产精品永久在线| 精品国产第1页| 国产精品多p对白交换绿帽| 国产精品无码一区二区三级| 国产高清在线精品一区小说 | 老司机午夜精品视频资源| 精品人妻中文字幕有码在线 | 成人国产一区二区三区精品| 国产精品国产三级国产| 久久丝袜精品中文字幕| 国产日韩高清三级精品人成| 欧洲精品一区二区三区在线观看| 亚洲国产av无码精品| 国产欧美日韩精品专区| 久久精品国产精品青草| 欧美日韩精品系列一区二区三区国产一区二区精品 | 亚洲国产一二三精品无码| 国产精品亲子乱子伦xxxx裸| 亚洲一级Av无码毛片久久精品 | 日韩精品在线看| 2020国产精品| 国产人成精品综合欧美成人 | 国产精品久久久久…| 免费精品国产自产拍在线观看 | 国产精品久久国产精麻豆99网站| 久久精品99久久香蕉国产色戒| 97久久久精品综合88久久| 无码国内精品人妻少妇| 亚洲综合一区二区精品导航| 国内精品久久久久久久97牛牛| 亚洲国产精品高清久久久| 中文字幕无码精品三级在线电影| 国产精品久久久福利| .精品久久久麻豆国产精品| 9久久9久久精品| 人妻无码精品久久亚瑟影视| 久久久精品久久久久久| 久久精品成人| 国产精品久久国产精麻豆99网站| 99热精品在线|