ホームページ PHPフレームワーク Laravel 1つの記事でlaravelモデルの削除とソフト削除について学びます

1つの記事でlaravelモデルの削除とソフト削除について学びます

Nov 20, 2019 pm 05:06 PM
laravel ソフトデリート

1つの記事で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 を使用します。このトレイトは、ソフト削除に関連する一連のメソッドを提供します。詳細については、ソース コード 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 = &#39;posts&#39;;
    //设置主键
    public $primaryKey = &#39;id&#39;;
    //设置日期时间格式
    public $dateFormat = &#39;U&#39;;
    protected $guarded = [&#39;id&#39;,&#39;views&#39;,&#39;user_id&#39;,&#39;updated_at&#39;,&#39;created_at&#39;];
    protected $dates = [&#39;delete_at&#39;];
}
ログイン後にコピー

次に、対応するデータベースポストに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(&#39;posts&#39;, function (Blueprint $table) {
            $table->softDeletes();
        });
    }
    ...//其它方法
}
ログイン後にコピー

次に、実行します:

php artisan migrate
ログイン後にコピー

したがって、投稿には [deleted_at] 列が存在します。次に、コントローラーにテスト コードを記述します。

$post = Post::find(6);
$post->delete();
if($post->trashed()){
    echo &#39;软删除成功!&#39;;
    dd($post);
}else{
    echo &#39;软删除失败!&#39;;
}
ログイン後にコピー

クエリ結果に論理的に削除されたレコードを含めたい場合はどうすればよいでしょうか? SoftDeletes トレイトで withTrashed メソッドを使用できます:

$posts = Post::withTrashed()->get();
dd($posts);
ログイン後にコピー

場合によっては、論理的に削除されたモデルのみを表示したい場合があります。SoftDeletes のonlyTrashed メソッドを使用するトリックもあります:

$posts = Post::onlyTrashed()->get();
dd($posts);
ログイン後にコピー

論理的削除による回復

論理的に削除されたモデルを復元する必要がある場合があります。SoftDeletes が提供する復元方法を使用できます:

単一のモデルを復元しますモデル

$post = Post::find(6);
$post->restore();
ログイン後にコピー
に問題があります。ID 6 のモデルは論理的に削除されました。Post::find(6) はデータを見つけることができません。

should

$post = Post::withTrashed()->find(6);
$post->restore();
ログイン後にコピー

複数のモデルを復元します

Post::withTrashed()->where(&#39;id&#39;,&#39;>&#39;,1)->restore();
ログイン後にコピー
すべてのモデルを復元します

Post::withTrashed()->restore();
ログイン後にコピー
関連するクエリ モデルを復元します

$post = Post::find(6);
$post->history()->restore();
ログイン後にコピー

強制削除

##モデルが論理的な削除で構成されているが、そのモデルに対応するデータベース テーブル レコードを実際に削除したい場合は、 SoftDeletes が提供する ForceDelete メソッドを使用できます。

$post = Post::find(6);
$post->forceDelete();
ログイン後にコピー
PHP 中国語 Web サイト、無料の

laravel 入門チュートリアル

が多数あり、オンラインで学習することを歓迎します。

この記事は、https://blog.csdn.net/weixin_38112233/article/details/78574007 から転載されました。

以上が1つの記事でlaravelモデルの削除とソフト削除について学びますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP でオブジェクト リレーショナル マッピング (ORM) を使用してデータベース操作を簡素化するにはどうすればよいですか? PHP でオブジェクト リレーショナル マッピング (ORM) を使用してデータベース操作を簡素化するにはどうすればよいですか? May 07, 2024 am 08:39 AM

PHP でのデータベース操作は、オブジェクトをリレーショナル データベースにマップする ORM を使用して簡素化されます。 Laravel の EloquentORM を使用すると、オブジェクト指向構文を使用してデータベースと対話できます。モデル クラスを定義したり、Eloquent メソッドを使用したり、実際にブログ システムを構築したりすることで ORM を使用できます。

Laravel と CodeIgniter の最新バージョンの比較 Laravel と CodeIgniter の最新バージョンの比較 Jun 05, 2024 pm 05:29 PM

Laravel 9 と CodeIgniter 4 の最新バージョンでは、更新された機能と改善が提供されます。 Laravel9はMVCアーキテクチャを採用しており、データベース移行、認証、テンプレートエンジンなどの機能を提供します。 CodeIgniter4 は、HMVC アーキテクチャを使用してルーティング、ORM、およびキャッシュを提供します。パフォーマンスの面では、Laravel9 のサービスプロバイダーベースの設計パターンと CodeIgniter4 の軽量フレームワークにより、優れたパフォーマンスが得られます。実際のアプリケーションでは、Laravel9 は柔軟性と強力な機能を必要とする複雑なプロジェクトに適しており、CodeIgniter4 は迅速な開発や小規模なアプリケーションに適しています。

Laravel - アーティザンコマンド Laravel - アーティザンコマンド Aug 27, 2024 am 10:51 AM

Laravel - アーティザン コマンド - Laravel 5.7 には、新しいコマンドを処理およびテストするための新しい方法が付属しています。これには職人コマンドをテストする新しい機能が含まれており、そのデモについては以下で説明します。

Laravel と CodeIgniter のデータ処理機能はどのように比較されますか? Laravel と CodeIgniter のデータ処理機能はどのように比較されますか? Jun 01, 2024 pm 01:34 PM

Laravel と CodeIgniter のデータ処理機能を比較します。 ORM: Laravel はクラスとオブジェクトのリレーショナル マッピングを提供する EloquentORM を使用しますが、CodeIgniter は ActiveRecord を使用してデータベース モデルを PHP クラスのサブクラスとして表します。クエリビルダー: Laravel には柔軟なチェーンクエリ API がありますが、CodeIgniter のクエリビルダーはよりシンプルで配列ベースです。データ検証: Laravel はカスタム検証ルールをサポートする Validator クラスを提供しますが、CodeIgniter には組み込みの検証関数が少なく、カスタム ルールの手動コーディングが必要です。実践例:ユーザー登録例はLarを示しています

Laravel と CodeIgniter ではどちらが初心者に優しいでしょうか? Laravel と CodeIgniter ではどちらが初心者に優しいでしょうか? Jun 05, 2024 pm 07:50 PM

初心者にとって、CodeIgniter は学習曲線が緩やかで機能は少ないですが、基本的なニーズはカバーしています。 Laravel は幅広い機能セットを提供しますが、学習曲線はわずかに急になります。パフォーマンスの点では、Laravel と CodeIgniter はどちらも良好なパフォーマンスを示します。 Laravel にはより広範なドキュメントとアクティブなコミュニティ サポートがあり、CodeIgniter はよりシンプルで軽量で、強力なセキュリティ機能を備えています。ブログアプリケーションを構築する実際のケースでは、Laravel の EloquentORM を使用するとデータ操作が簡素化されますが、CodeIgniter ではより手動の構成が必要になります。

Laravel と CodeIgniter: 大規模プロジェクトにはどちらのフレームワークが適していますか? Laravel と CodeIgniter: 大規模プロジェクトにはどちらのフレームワークが適していますか? Jun 04, 2024 am 09:09 AM

大規模プロジェクト用のフレームワークを選択する場合、Laravel と CodeIgniter にはそれぞれ独自の利点があります。 Laravel はエンタープライズレベルのアプリケーション向けに設計されており、モジュール設計、依存関係の注入、強力な機能セットを提供します。 CodeIgniter は、速度と使いやすさを重視した、小規模から中規模のプロジェクトに適した軽量フレームワークです。複雑な要件と多数のユーザーを伴う大規模なプロジェクトには、Laravel のパワーとスケーラビリティがより適しています。単純なプロジェクトやリソースが限られている状況では、CodeIgniter の軽量で迅速な開発機能がより理想的です。

PHPコードの単体テストと統合テスト PHPコードの単体テストと統合テスト May 07, 2024 am 08:00 AM

PHP 単体テストおよび統合テスト ガイド 単体テスト: コードまたは関数の単一単位に焦点を当て、PHPUnit を使用して検証用のテスト ケース クラスを作成します。統合テスト: 複数のコードユニットがどのように連携するかに注意し、PHPUnit の setUp() メソッドと TearDown() メソッドを使用してテスト環境をセットアップおよびクリーンアップします。実際のケース: PHPUnit を使用して、データベースの作成、サーバーの起動、テストコードの作成など、Laravel アプリケーションの単体テストと統合テストを実行します。

Laravel と CodeIgniter: 小規模プロジェクトにはどちらのフレームワークが適していますか? Laravel と CodeIgniter: 小規模プロジェクトにはどちらのフレームワークが適していますか? Jun 04, 2024 pm 05:29 PM

小規模なプロジェクトの場合、Laravel は強力な機能とセキュリティを必要とする大規模なプロジェクトに適しています。 CodeIgniter は、軽量さと使いやすさを必要とする非常に小規模なプロジェクトに適しています。

See all articles