検索
ホームページPHPフレームワークLaravellaravelテーブルの追加、削除、変更

Laravel は、開発者が Web アプリケーションを迅速に構築できるようにする便利なツールと機能を提供する人気の PHP フレームワークです。基本的な機能の1つはテーブルを使用してデータを追加、削除、変更、クエリすることですが、この記事ではこれらの機能をLaravelで実装する方法を紹介します。

  1. データベースとテーブルの作成

まず、データを保存するためのデータベースとデータ テーブルを作成する必要があります。この記事では、ID、名前、電子メール、パスワードのフィールドを含む「users」というテーブルを作成します。

Laravel で移行を使用してテーブルを作成できます。コマンドラインで次のコマンドを実行します:

php artisan make:migration create_users_table --create=users

このコマンドを実行すると、Laravel は「database/migrations」ディレクトリに新しい移行ファイルを作成します。移行ファイルの「Schema」クラスを使用してテーブル構造を定義できます。コードは次のとおりです。

use IlluminateDatabaseMigrationsMigration;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateSupportFacadesSchema;

class CreateUsersTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->increments('id');
            $table->string('name');
            $table->string('email')->unique();
            $table->string('password');
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('users');
    }
}

上記のコードは、ID、名前、電子メール、パスワード、およびタイムスタンプのフィールドを含む「users」という名前のテーブルを作成します。

移行を実行すると、Laravel はデータベースにテーブルを作成します。次のコマンドを実行して移行します。

php artisan migrate
  1. レコードの追加

レコードをテーブルに追加するには、コントローラーを作成し、モデルを使用してデータを保存する必要があります。データベース。コマンド ラインで次のコマンドを実行します。

php artisan make:controller UserController

このコマンドは、"app/Http/Controllers" ディレクトリに新しい "UserController" コントローラーを作成します。

コントローラー ファイルでは、「create」メソッドを使用して新しいレコードを保存できます。サンプル コードは次のとおりです。

use AppUser;
use IlluminateHttpRequest;

class UserController extends Controller
{
    public function store(Request $request)
    {
        $user = User::create([
            'name' => $request->input('name'),
            'email' => $request->input('email'),
            'password' => bcrypt($request->input('password')),
        ]);

        return response()->json([
            'message' => 'User created successfully',
            'user' => $user,
        ]);
    }
}

上記のコードでは、最初に「User」モデルをインポートし、次に「store」メソッドの「create」メソッドを使用して新しいレコードを作成します。リクエストの「名前」、「電子メール」、「パスワード」フィールドをパラメータとして使用し、「bcrypt」関数を使用してパスワードを暗号化します。最後に、作成されたユーザー レコードを含む JSON 応答を返します。

  1. レコードのリスト

コントローラーを使用してテーブル内のすべてのレコードを取得し、ユーザーに返すことができます。コントローラーに次のコードを追加します。

public function index()
{
    $users = User::all();

    return view('users.index', ['users' => $users]);
}

上記のコードは、「all」メソッドを使用してユーザー テーブル内のすべてのレコードを取得し、結果をビューに渡します。このデータをビューで使用して、HTML テーブルをレンダリングできます。

  1. レコードの更新

レコードを作成する場合と同様に、モデルとコントローラーを使用してレコードを更新できます。 「update」メソッドの例を次に示します。

public function update(Request $request, $id)
{
    $user = User::find($id);

    $user->name = $request->input('name');
    $user->email = $request->input('email');

    if ($request->input('password')) {
        $user->password = bcrypt($request->input('password'));
    }

    $user->save();

    return response()->json([
        'message' => 'User updated successfully',
        'user' => $user,
    ]);
}

上記のコードでは、まず「find」メソッドを使用して、指定された ID を持つユーザー レコードを取得します。次に、リクエストの「名前」フィールドと「電子メール」フィールドを属性値として使用して、レコードを更新します。リクエストに「パスワード」フィールドが含まれている場合、「bcrypt」関数を使用して暗号化され、ユーザー レコードが更新されます。最後に、「save」メソッドを使用してレコードを保存し、更新されたユーザー レコードを JSON 応答として返します。

  1. レコードの削除

コントローラーとモデルを使用してユーザー レコードを削除できます。 「destroy」メソッドの例を次に示します。

public function destroy($id)
{
    $user = User::find($id);

    $user->delete();

    return response()->json([
        'message' => 'User deleted successfully',
    ]);
}

上記のコードでは、まず「find」メソッドを使用して、指定された ID を持つユーザー レコードを取得します。その後、「delete」メソッドを使用してレコードを削除する前に、レコードに対して他の操作を実行できます。最後に、削除されたユーザーに関する情報を含む JSON 応答を返します。

  1. テーブル ビュー

すべてのユーザー レコードをリストする場合、ビューを使用して HTML テーブルをレンダリングできます。サンプル ビュー コードは次のとおりです。

<table>
    <thead>
        <tr>
            <th>ID</th>
            <th>Name</th>
            <th>Email</th>
            <th>Action</th>
        </tr>
    </thead>
    <tbody>
        @foreach ($users as $user)
            <tr>
                <td>{{ $user->id }}</td>
                <td>{{ $user->name }}</td>
                <td>{{ $user->email }}</td>
                <td>
                    <a href="{{ route('users.edit', $user->id) }}">Edit</a>
                    <form action="{{ route('users.destroy', $user->id) }}" method="POST">
                        {{ csrf_field() }}
                        {{ method_field('DELETE') }}
                        <button type="submit">Delete</button>
                    </form>
                </td>
            </tr>
        @endforeach
    </tbody>
</table>

上記のコードでは、「@foreach」ディレクティブを使用してすべてのユーザー レコードをループし、HTML テーブルにユーザーの ID、名前、電子メールを表示しています。さらに、「編集」と「削除」という 2 つのアクション列を追加しました。削除の場合は、フォームを使用して DELETE リクエストを送信し、「csrf_field」ディレクティブを使用して CSRF トークンを追加します。編集のために、ルート内に個別のビューとコントローラーを定義します。

  1. 結論

この記事では、Laravel でモデルとコントローラーを使用して、基本的なテーブルの追加、削除、変更、クエリ操作を実行する方法を紹介しました。実際のプロジェクトにはさらに多くの機能や詳細が含まれる可能性がありますが、この記事は、Laravel を使用して Web アプリケーションのテーブル操作を処理し始めるのに役立つ出発点を提供します。

以上がlaravelテーブルの追加、削除、変更の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Laravel(PHP)vs。Python:開発環境とエコシステムLaravel(PHP)vs。Python:開発環境とエコシステムApr 12, 2025 am 12:10 AM

開発環境とエコシステムにおけるLaravelとPythonの比較は次のとおりです。1。Laravelの開発環境は簡単で、PHPと作曲家のみが必要です。 Laravelforgeなどの豊富な範囲の拡張パッケージを提供しますが、拡張パッケージのメンテナンスはタイムリーではない場合があります。 2。Pythonの開発環境もシンプルで、PythonとPIPのみが必要です。エコシステムは巨大で複数のフィールドをカバーしていますが、バージョンと依存関係の管理は複雑な場合があります。

LaravelとThe BackEnd:Webアプリケーションロジックの電源LaravelとThe BackEnd:Webアプリケーションロジックの電源Apr 11, 2025 am 11:29 AM

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

Laravelがそんなに人気があるのはなぜですか?Laravelがそんなに人気があるのはなぜですか?Apr 02, 2025 pm 02:16 PM

Laravelの人気には、単純化された開発プロセスが含まれ、快適な開発環境を提供し、豊富な機能が提供されます。 1)Rubyonrailsの設計哲学を吸収し、PHPの柔軟性を組み合わせています。 2)Eloquentorm、Bladeテンプレートエンジンなどのツールを提供して、開発効率を向上させます。 3)そのMVCアーキテクチャと依存関係噴射メカニズムにより、コードがよりモジュール化され、テスト可能になります。 4)キャッシュシステムやベストプラクティスなどの強力なデバッグツールとパフォーマンス最適化方法を提供します。

どちらが良いのか、DjangoとLaravel?どちらが良いのか、DjangoとLaravel?Mar 28, 2025 am 10:41 AM

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

どちらがより良いPHPですか、それともLaravelですか?どちらがより良いPHPですか、それともLaravelですか?Mar 27, 2025 pm 05:31 PM

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

Laravelはフロントエンドですか、それともバックエンドですか?Laravelはフロントエンドですか、それともバックエンドですか?Mar 27, 2025 pm 05:31 PM

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

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

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

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

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

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

メモ帳++7.3.1

メモ帳++7.3.1

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

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境