ホームページ PHPフレームワーク Laravel laravelのdeleteの書き方

laravelのdeleteの書き方

May 26, 2023 pm 01:46 PM

Laravel は、強力な機能と使いやすさで開発者の間で人気のある PHP Web フレームワークです。実際の開発では、データベース内のデータを削除する必要があることがよくあります。この記事では、Laravelをよりよく理解して使用するために、Laravelでの削除の書き方を紹介します。

  1. 単一データを削除する

Laravel では単一データを削除するためのさまざまなメソッドが用意されています。以下にそれらを紹介します。

(1) モデルに付属の delete() メソッドを使用する

Laravel では、各モデルに、そのモデルに対応するデータベースを削除するために使用できる delete() メソッドが付属しています。 。 記録。以下は、使用方法のサンプル コードです。

$user = User::find(1);
$user->delete();
ログイン後にコピー
ログイン後にコピー

上記のコードでは、まず User モデルの find() メソッドを使用して ID 1 のレコードを検索し、次に delete() メソッドを呼び出します。レコードを削除するメソッド。

delete() メソッドは他のモデルがレコードに依存しているかどうかをチェックしないので、レコードを削除する前に他のモデルが他のデータに関連付けられていないことを確認する必要があることに注意してください。

(2) ORM の destroy() メソッドを使用する

ORM (オブジェクト リレーショナル マッピング) は、オブジェクトをリレーショナル データベース内のデータにマッピングするテクノロジです。 LaravelにはORM機能が組み込まれており、そのdestroy()メソッドを使用してモデルに対応するデータベースレコードを削除できます。

以下は、ORM の destroy() メソッドを使用して 1 つのレコードを削除するサンプル コードです。

User::destroy(1);
ログイン後にコピー

上記のコードでは、User モデルの destroy() メソッドを直接呼び出し、削除するレコードの ID を渡します。

destroy() メソッドは、他のモデルがレコードに依存しているかどうかをチェックしないことに注意してください。そのため、レコードを削除する前に、他のモデルが他のデータに関連付けられていないことを確認する必要があります。

(3) クエリビルダーの delete() メソッドを使用する

クエリビルダーは、チェーンコールに基づいた Laravel の SQL ステートメントビルダーです。データを削除するメソッド delete() など、データベースを操作するためのメソッドが豊富に用意されています。

以下は、クエリ ビルダーの delete() メソッドを使用して単一のレコードを削除するサンプル コードです。

DB::table('users')->where('id', 1)->delete();
ログイン後にコピー

上記のコードでは、DB (データベース) ファサードを使用してテーブル( ) メソッドを使用して削除するレコードを指定します。データ テーブル名、次に where() メソッドを使用して削除する条件を指定し、最後に delete() メソッドを呼び出して削除操作を実行します。

delete() メソッドはモデルのイベントとフックをトリガーしないことに注意してください。そのため、これらの関数を使用する場合は、上記のメソッドのいずれかを使用することをお勧めします。

  1. データをバッチで削除する

Laravel では、単一のデータベース レコードを削除するだけでなく、データをバッチで削除する便利な方法も提供しています。以下に、一般的に使用される 2 つの一括削除方法を紹介します。

(1) ORM の delete() メソッドを使用する

ORM の delete() メソッドは、単一のレコードを削除するだけでなく、複数のレコードを一括して削除することもできます。以下は、このメソッドを使用してレコードをバッチで削除するサンプル コードです。

User::where('age', '>', 18)->delete();
ログイン後にコピー

上記のコードでは、最初に where() メソッドを使用して 18 歳以上のユーザーを除外し、次にこれらのレコードを削除するには、delete() メソッドを使用します。

delete() メソッドはモデルのイベントとフックをトリガーしないことに注意してください。そのため、これらの関数を使用する場合は、上記のメソッドのいずれかを使用することをお勧めします。

(2) クエリ ビルダーの delete() メソッドを使用する

クエリ ビルダーの delete() メソッドを使用して、レコードをバッチで削除することもできます。このメソッドを使用してレコードを一括削除するサンプル コードを次に示します。

DB::table('users')->where('age', '>', 18)->delete();
ログイン後にコピー

上記のコードでは、where() メソッドを使用して削除する条件を指定し、delete() メソッドを使用します。削除操作を実行します。

delete() メソッドはモデルのイベントとフックをトリガーしないことに注意してください。そのため、これらの関数を使用する場合は、上記のメソッドのいずれかを使用することをお勧めします。

  1. ソフト削除

実際の開発では、後で復元できるように削除されたデータの記録を保持する必要がある場合があります。この時点で、論理的な削除が役に立ちます。 Laravel には、安全な方法でデータを削除するのに役立つ論理的な削除機能が組み込まれています。

論理的な削除の実装の中心となるアイデアは、deleted_at フィールドをデータベース テーブルに追加して、削除時間を記録することです。データをクエリするとき、Laravel は論理的に削除されたレコードを自動的にフィルターして、クエリ結果に表示されないようにします。

以下は、Laravel を使用してソフト削除を実装するサンプル コードです:

まず、モデルで SoftDeletes トレイトを使用する必要があります:

<?php

namespace App;

use IlluminateDatabaseEloquentModel;
use IlluminateDatabaseEloquentSoftDeletes;

class User extends Model
{
    use SoftDeletes;
}
ログイン後にコピー

次に、deleted_at を追加します。データベース移行のフィールド:

Schema::table('users', function (Blueprint $table) {
    $table->softDeletes();
});
ログイン後にコピー

最後に、コントローラーの delete() メソッドを使用してデータをソフト削除します:

$user = User::find(1);
$user->delete();
ログイン後にコピー
ログイン後にコピー

削除されたデータを回復する必要がある場合は、 restore() メソッド:

$user = User::withTrashed()->find(1);
$user->restore();
ログイン後にコピー

ソフト削除を使用すると、データを誤って削除することを心配することなく、削除されたデータをより適切に管理できます。ただし、論理的な削除は普遍的なソリューションではないことに注意してください。ビジネス シナリオによっては、データの整合性とセキュリティを確保するためにデータを完全に削除する必要がある場合があります。

要約

Laravel はデータを削除するための豊富な方法を提供しており、特定のビジネス ニーズに応じてさまざまな方法を選択できます。実際の開発では、データの整合性やセキュリティを確保するために、状況に応じてソフト削除や一括削除などの操作を使用するかを慎重に検討する必要があります。また、データを削除すると他の機種や機能の正常な動作に影響を与える可能性があり、十分なテストと検証が必要となりますのでご注意ください。

以上がlaravelのdeleteの書き方の詳細内容です。詳細については、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)

LaravelでOAUTH2認証と承認を実装する方法は? LaravelでOAUTH2認証と承認を実装する方法は? Mar 12, 2025 pm 05:56 PM

この記事では、LaravelでOAUTH 2.0認証と承認を実装しています。 League/OAuth2-Serverやプロバイダー固有のソリューションなどのパッケージを使用して、データベースのセットアップ、クライアント登録、承認サーバー構成を強調しています

Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか? Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか? Mar 17, 2025 pm 02:47 PM

この記事では、コンポーネントを使用してLaravelで再利用可能なUI要素の作成とカスタマイズについて説明し、組織のベストプラクティスを提供し、パッケージを強化することを提案します。

クラウドネイティブ環境でLaravelを使用するためのベストプラクティスは何ですか? クラウドネイティブ環境でLaravelを使用するためのベストプラクティスは何ですか? Mar 14, 2025 pm 01:44 PM

この記事では、スケーラビリティ、信頼性、セキュリティに焦点を当てたクラウドネイティブ環境でLaravelを展開するためのベストプラクティスについて説明します。重要な問題には、コンテナ化、マイクロサービス、ステートレス設計、最適化戦略が含まれます。

Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか? Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか? Mar 17, 2025 pm 02:50 PM

この記事では、Laravelでカスタムブレードディレクティブの作成と使用を行い、テンプレートを強化します。ディレクティブの定義、テンプレートでそれらを使用し、大規模なプロジェクトでそれらを管理することをカバーし、改善されたコードの再利用性やRなどの利点を強調しています

Laravelでカスタム検証ルールを作成して使用するにはどうすればよいですか? Laravelでカスタム検証ルールを作成して使用するにはどうすればよいですか? Mar 17, 2025 pm 02:38 PM

この記事では、Laravelでカスタム検証ルールの作成と使用について説明し、それらを定義および実装する手順を提供します。再利用性や特異性などの利点を強調し、Laravelの検証システムを拡張する方法を提供します。

Laravelでファイルアップロードとクラウドストレージを処理する最良の方法は何ですか? Laravelでファイルアップロードとクラウドストレージを処理する最良の方法は何ですか? Mar 12, 2025 pm 05:54 PM

この記事では、Laravelの最適なファイルアップロードとクラウドストレージ戦略を調べます。 ローカルストレージとクラウドプロバイダー(AWS S3、Google Cloud、Azure、DigitalOcean)、セキュリティ(検証、消毒、HTTPS)およびパフォーマンスオプティを強調しています

Laravelの職人コンソールを使用して一般的なタスクを自動化するにはどうすればよいですか? Laravelの職人コンソールを使用して一般的なタスクを自動化するにはどうすればよいですか? Mar 17, 2025 pm 02:39 PM

Laravelの職人コンソールは、コードの生成、移行の実行、スケジューリングなどのタスクを自動化します。重要なコマンドには、Make:Controller、Migrate、およびDB:Seedが含まれます。特定のニーズに合わせてカスタムコマンドを作成し、ワークフロー効率を向上させることができます。

Laravelのルーティング機能を使用して、SEOに優しいURLを作成するにはどうすればよいですか? Laravelのルーティング機能を使用して、SEOに優しいURLを作成するにはどうすればよいですか? Mar 17, 2025 pm 02:43 PM

この記事では、Laravelのルーティングを使用してSEOに優しいURLを作成し、Best Practice、Canonical URL、SEO最適化のツールをカバーします。ワード数:159

See all articles