ホームページ >PHPフレームワーク >Laravel >Laravelを使用したデータベースの移行と追加: データ構造の変更を柔軟に管理

Laravelを使用したデータベースの移行と追加: データ構造の変更を柔軟に管理

WBOY
WBOYオリジナル
2023-08-25 15:21:08982ブラウズ

Laravelを使用したデータベースの移行と追加: データ構造の変更を柔軟に管理

Laravel を使用したデータベースの移行と充填: データ構造の変更の柔軟な管理

はじめに:
開発プロセスでは、データベース構造が変更される状況によく遭遇します。変更が必要です。データベースの管理とメンテナンスを容易にするために、Laravel はデータベースの移行と充填機能を提供します。マイグレーションとポピュレーションを使用することで、データベース構造の変更に柔軟に対応し、異なる開発環境でのデータベースの一貫性を確保できます。この記事では、Laravel を使用してデータベースの移行と充填を行う方法とコード例を詳しく紹介します。

1. データベースの移行
データベースの移行とは、既存のデータを失わずにデータベースの構造を変更することを指します。 Laravel は、テーブル、カラム、インデックスなどのデータベース オブジェクトを簡単に作成、変更、削除できる豊富な移行機能を提供します。

  1. 移行ファイルの作成
    Laravel Artisan コマンド ライン ツールを使用して、移行ファイルをすばやく作成します。コマンド ラインに次のコマンドを入力します。

    php artisan make:migration create_users_table --create=users

    これにより、YYYY_MM_DD_HHMMSS_create_users_table.php という名前の移行ファイルが database/migrations ディレクトリに作成されます。

  2. 移行ファイルの編集
    生成されたばかりの移行ファイルを開くと、up メソッドにテーブルを作成するコードを追加できます。たとえば、users という名前のテーブルを作成し、2 つの列 nameemail を追加するとします。コードは次のとおりです。

    public function up()
    {
     Schema::create('users', function (Blueprint $table) {
         $table->id();
         $table->string('name');
         $table->string('email')->unique();
         $table->timestamps();
     });
    }

    テーブルの作成が完了したら、Laravel が提供する一連のメソッドを使用して、テーブル構造を変更したり、インデックスを追加したりすることもできます。具体的な方法についてはLaravelの公式ドキュメントを参照してください。

  3. 移行の実行
    コマンドラインに次のコマンドを入力して、移行を実行します:

    php artisan migrate

    Laravel は、up# で定義された操作を自動的に実行します。 ## メソッドで、users テーブルを作成します。

  4. 移行を元に戻す

    移行を元に戻す必要がある場合は、次のコマンドを使用できます:

    php artisan migrate:rollback

    Laravel は自動的に

    down を呼び出します。移行ファイルのメソッドを使用して、移行操作をキャンセルします。

2. データベースの充填

データベースの充填は、テスト データまたは初期データをデータベース テーブルに挿入するプロセスです。 Laravel は、さまざまなタイプのテストデータを簡単に生成および挿入できる強力な埋め込み関数を提供します。

  1. 塗りつぶしファイルの作成

    Laravel Artisan コマンド ライン ツールを使用して、塗りつぶしファイルをすばやく作成します。コマンド ラインで次のコマンドを入力します。

    php artisan make:seeder UsersTableSeeder

    これにより、

    database/seeders ディレクトリに UsersTableSeeder.php という名前の入力ファイルが作成されます。

  2. 塗りつぶしファイルを編集する

    生成したばかりの塗りつぶしファイルを開き、
    run メソッドにデータを挿入するコードを記述します。たとえば、users テーブルに 3 つのテスト データを挿入する場合、コードは次のとおりです。埋め込みを実行するには、コマンドラインで次のコマンドを実行します。

    public function run()
    {
     DB::table('users')->insert([
         ['name' => 'John', 'email' => 'john@example.com'],
         ['name' => 'Jane', 'email' => 'jane@example.com'],
         ['name' => 'Mike', 'email' => 'mike@example.com'],
     ]);
    }

    Laravel は、埋め込みファイル内の
  3. run
  4. メソッドを自動的に実行し、テスト データを

    users
    テーブルに挿入します。

    塗りつぶしを元に戻す塗りつぶしを元に戻す必要がある場合は、次のコマンドを使用できます:

    php artisan db:seed --class=UsersTableSeeder

    Laravel は自動的に
  5. down
  6. 充填ファイルのメソッドで、設定されたデータを削除します。


    要約: Laravel のデータベース移行および充填機能を使用することで、データベース構造の変更をより柔軟に管理および維持できます。移行とコード バージョン管理ツールの入力を組み合わせることで、さまざまな開発環境でデータベースの一貫性を確保し、チームのコラボレーション効率を向上させることができます。この記事がLaravelのデータベース移行と充填機能をマスターするのに役立つことを願っています。

    注: 上記のコード例は、Laravel 8.0 バージョンに基づいています。 Laravelのバージョンが異なると若干の違いがある場合がありますので、実際の状況に応じて調整してください。

以上がLaravelを使用したデータベースの移行と追加: データ構造の変更を柔軟に管理の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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