##1. モデルを削除します
#1.1 delete を使用してモデルを削除します##モデルの削除は非常に簡単です。まず、削除するモデル インスタンスを取得し、次に delete メソッドを呼び出します:
$post = Post::find(5); if($post->delete()){ echo '删除文章成功!'; }else{ echo '删除文章失败!'; }
1.2 destroy を使用してモデルを削除する
もちろん、削除するモデル ID がわかっている場合は、より簡単なメソッド destroy を使用して直接削除できます。
$deleted = Post::destroy(5);
$deleted = Post::destroy([1,2,3,4,5]);
1.3 クエリ ビルダーを使用してモデルを削除する
Eloquent モデル自体がクエリ ビルダーであることは前述したように、クエリ ビルダーを削除することもできます。クエリ ビルダー スタイルを使用したモデル。たとえば、ビューが 0 の記事をすべて削除したい場合は、次のメソッドを使用できます。
$deleted = Models\Post::where('views', 0)->delete();
上記の削除メソッドは、データベースからデータ テーブル レコードを削除します。さらに、Eloquent モデルもソフト削除をサポートします。
いわゆるソフト削除とは、データ テーブルのレコードが実際にはデータベースから削除されないことを意味しますが、テーブル レコードの識別ステータスはソフト削除としてマークされ、クエリ時にフィルタリングできるようになります。対応するテーブルのレコードが「削除」されたようです。 Laravel は識別ステータスとして日付フィールドを使用します。この日付フィールドはカスタマイズできます。ここでは、deleted_at を使用します。対応するモデルが論理的に削除されている場合、deleted_at フィールドの値は削除時刻です。それ以外の場合、値は空です。Eloquent モデルでソフト削除をサポートするには、いくつかの設定を行う必要があります。まず、モデル クラスで SoftDeletestrait を使用します。このトレイトは、ソフト削除に関連する一連のメソッドを提供します。詳細については、ソース コード 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']; }
次に、対応するデータベースポストにdeleted_at列を追加します。これを実装するには移行を使用します。最初にArtisanコマンドを実行します:
php artisan make:migration alter_posts_deleted_at --table=posts
<?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
$post = Post::find(6); $post->delete(); if($post->trashed()){ echo '软删除成功!'; dd($post); }else{ echo '软删除失败!'; }
$posts = Post::withTrashed()->get(); dd($posts);
$posts = Post::onlyTrashed()->get(); dd($posts);
論理的に削除されたモデルを復元する必要がある場合があります。SoftDeletes が提供する復元方法を使用できます:
単一のモデルを復元しますモデル
$post = Post::find(6); $post->restore();
$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();
が多数あり、オンラインで学習することを歓迎します。
この記事は、https://blog.csdn.net/weixin_38112233/article/details/78574007 から転載されました。
以上が1つの記事でlaravelモデルの削除とソフト削除について学びますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。