1つの記事でlaravelモデルの削除とソフト削除について学びます
##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 サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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