Laravel で論理的に削除されたデータがどのように引き続き読み取れるかについての簡単な分析
Laravel は、Web アプリケーション開発プロセスを簡素化する多くの強力な機能とツールを提供する人気のある PHP Web アプリケーション フレームワークです。中でもLaravelのソフト削除機能は非常に便利な機能で、データベースからレコードをすぐに削除するのではなく、レコードを削除済みとしてマークすることで、データの整合性を保ちながら特殊なニーズを実現できます。
しかし、多くの Laravel 開発者が遭遇したであろう疑問は、論理的に削除されたデータは引き続き読み取ることができるかということです。この記事では、この問題とその解決策について説明します。
まず、Laravel のソフト削除の原理を理解する必要があります。論理的な削除は、deleted_at フィールドをデータ テーブルに追加することによって実装されます。論理的な削除を使用する場合、レコードが削除されると、Laravel はレコードを削除するのではなく、レコードの delete_at フィールドを空ではない値に設定するだけで、「論理的な削除」の効果が得られます。データをクエリするとき、Laravelは空ではないdeleted_atフィールドを持つレコードを自動的に除外し、「論理的に削除」されていないレコードのみをクエリする効果を実現します。
したがって、論理的に削除されたレコードがデータベースにまだ存在する場合でも、論理的に削除されたデータは引き続き読み出すことができます。ただし、デフォルトでは、Laravel の論理的な削除は、「論理的に削除された」とマークされたレコードのみを自動的にフィルターします。論理的に削除されたレコードと削除されていないレコードの両方をクエリする必要がある場合は、手動で withTrashed メソッドをクエリに追加する必要があります。
withTrashed メソッドは論理的に削除されたレコードを返しますが、論理的に削除されていないレコードのクエリには引き続き通常のメソッドが使用されます:
// 查询未被软删除的记录 $users = DB::table('users')->whereNull('deleted_at')->get(); // 查询被软删除的记录 $trashedUsers = DB::table('users')->whereNotNull('deleted_at')->get(); // 同时查询未被软删除和被软删除的记录 $usersWithTrashed = DB::table('users')->withTrashed()->get();
上の例では、whereNull メソッドと whereNotNull メソッドを使用してクエリを実行しました。削除されていないレコード。削除されたレコードと削除されたレコード、および withTrashed メソッドは、論理的に削除されたレコードのクエリにも使用されます。
withTrashed メソッドに加えて、Laravel には他にも 2 つのメソッドがあります。onlyTrashed と復元です。これらは、論理的に削除されたレコードをクエリし、論理的に削除されたレコードを復元するために使用されます。その使用法は次のとおりです:
// 查询被软删除的记录 $trashedUsers = DB::table('users')->onlyTrashed()->get(); // 恢复软删除的记录 DB::table('users')->where('id', $id)->restore();
要約すると、Laravel で論理的に削除されたデータは引き続き読み出すことができますが、デフォルトでは論理的に削除されていないレコードのみがクエリされます。論理的に削除されたレコードと削除が取り消されたレコードを同時にクエリする必要がある場合は、withTrashed メソッドを手動で追加する必要があります。さらに、onlyTrashed メソッドを使用して論理的に削除されたレコードをクエリしたり、restore メソッドを使用して論理的に削除されたレコードを復元したりすることもできます。これらの方法をマスターすることで、開発者はLaravelのソフト削除機能をより適切に適用し、開発効率を向上させることができます。
以上がLaravel で論理的に削除されたデータがどのように引き続き読み取れるかについての簡単な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











DjangoとLaravelはどちらもフルスタックのフレームワークです。 DjangoはPython開発者や複雑なビジネスロジックに適していますが、LaravelはPHP開発者とエレガントな構文に適しています。 1.DjangoはPythonに基づいており、迅速な発展と高い並行性に適した「バッテリーコンプリート」哲学に従います。 2. LaravelはPHPに基づいており、開発者エクスペリエンスを強調しており、小規模から中規模のプロジェクトに適しています。

Laravelはバックエンドロジックでどのように役割を果たしますか?ルーティングシステム、Eloquentorm、認証と承認、イベントとリスナー、パフォーマンスの最適化を通じてバックエンド開発を簡素化および強化します。 1.ルーティングシステムにより、URL構造の定義とリクエスト処理ロジックが可能になります。 2.Eloquentormは、データベースの相互作用を簡素化します。 3.認証および承認システムは、ユーザー管理に便利です。 4.イベントとリスナーは、ゆるく結合したコード構造を実装します。 5.パフォーマンスの最適化により、キャッシュとキューイングを通じてアプリケーションの効率が向上します。

LaravelはPHPベースのフレームワークであるため、PHPとLaravelは直接匹敵するものではありません。 1.PHPは、シンプルで直接的であるため、小規模プロジェクトや迅速なプロトタイピングに適しています。 2。LARAVELは、豊富な機能とツールを提供するため、大規模なプロジェクトや効率的な開発に適していますが、急な学習曲線があり、純粋なPHPほど良くない場合があります。

laravelisabackendframeworkbuiltonphp、designforwebapplicationdevelopment.itfocusonserver-sidelogic、databasemanagement、およびapplicationStructure、およびbueithedendtechnologiesvue.jsorreactforfull-stackdevelymentと統合されていること。

Laravelは、Webアプリケーションを簡単に構築するためのPHPフレームワークです。次のような強力な機能を提供します。インストール:Laravel CLIを作曲家にグローバルにインストールし、プロジェクトディレクトリにアプリケーションを作成します。ルーティング:ルート/web.phpのURLとハンドラーの関係を定義します。ビュー:リソース/ビューでビューを作成して、アプリケーションのインターフェイスをレンダリングします。データベース統合:MySQLなどのデータベースとのすぐ外側の統合を提供し、移行を使用してテーブルを作成および変更します。モデルとコントローラー:モデルはデータベースエンティティを表し、コントローラーはHTTP要求を処理します。

Laravelフレームワークを学びたいが、資源や経済的圧力に苦しんでいないのですか?この記事では、Laravelの無料学習を提供し、オンラインプラットフォーム、ドキュメント、コミュニティフォーラムなどのリソースを使用して、PHP開発の旅から習得するための堅実な基盤を築く方法を教えてくれます。

Laravel Developmentプロジェクトは、さまざまなサイズと複雑さのニーズに合う柔軟性とパワーのために選択されました。 Laravelは、ルーティングシステム、Eloquentorm、Artisan Command Lineおよびその他の機能を提供し、簡単なブログから複雑なエンタープライズレベルのシステムへの開発をサポートしています。

Laravelは、ユーザーモデル(Eloquentモデル)の定義、ログインフォームの作成(ブレードテンプレートエンジン)、ログインコントローラーの作成(認証\ログインコントローラーの継承)、ログイン要求の検証(Auth ::試行)の検証など、ユーザーログイン機能を実装するための包括的なAuthフレームワークを提供します。ヘッダー。さらに、AUTHフレームワークは、パスワードのリセット、電子メールの登録と検証などの機能も提供します。詳細については、Laravelのドキュメントを参照してください:https://laravel.com/doc
