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

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

Aug 25, 2023 pm 03:21 PM
laravel データベースの移行 データ充填

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 までご連絡ください。

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の 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で電子メールの送信が失敗したときに返品コードを取得する方法は? Laravelで電子メールの送信が失敗したときに返品コードを取得する方法は? Apr 01, 2025 pm 02:45 PM

Laravelの電子メールの送信が失敗したときに戻りコードを取得する方法。 Laravelを使用してアプリケーションを開発する場合、検証コードを送信する必要がある状況に遭遇することがよくあります。そして実際には...

DCAT管理者にデータを追加するためにクリックのカスタムテーブル関数を実装する方法は? DCAT管理者にデータを追加するためにクリックのカスタムテーブル関数を実装する方法は? Apr 01, 2025 am 07:09 AM

DCATを使用するときにDCATADMIN(Laravel-Admin)にデータを追加するためにカスタムクリックのテーブル関数を実装する方法...

Laravel Redis接続共有:選択方法が他の接続に影響するのはなぜですか? Laravel Redis接続共有:選択方法が他の接続に影響するのはなぜですか? Apr 01, 2025 am 07:45 AM

Laravel FrameworkでRedis接続の共有の影響とLaravelフレームワークとRedisを使用する際のメソッドを選択すると、開発者は問題に遭遇する可能性があります。

Laravel Multi-Tenant Extension Stancl/Tenancy:テナントデータベース接続のホストアドレスをカスタマイズする方法は? Laravel Multi-Tenant Extension Stancl/Tenancy:テナントデータベース接続のホストアドレスをカスタマイズする方法は? Apr 01, 2025 am 09:09 AM

Laravel Multi-Tenant拡張機能パッケージStancl/Tenancyのカスタムテナントデータベース接続Laravel Multi-Tenant ExtensionパッケージStancl/Tenancyを使用したマルチテナントアプリケーションを構築する際の...

バングラ部分モデル検索のlaravelEloquent orm) バングラ部分モデル検索のlaravelEloquent orm) Apr 08, 2025 pm 02:06 PM

LaravelEloquentモデルの検索:データベースデータを簡単に取得するEloquentormは、データベースを操作するための簡潔で理解しやすい方法を提供します。この記事では、さまざまな雄弁なモデル検索手法を詳細に紹介して、データベースからのデータを効率的に取得するのに役立ちます。 1.すべてのレコードを取得します。 ALL()メソッドを使用して、データベーステーブルですべてのレコードを取得します:useapp \ models \ post; $ post = post :: all();これにより、コレクションが返されます。 Foreach Loopまたはその他の収集方法を使用してデータにアクセスできます。

Laravel6プロジェクトでRedis接続の有効性を効果的に確認する方法は? Laravel6プロジェクトでRedis接続の有効性を効果的に確認する方法は? Apr 01, 2025 pm 02:00 PM

Laravel6プロジェクトでRedis接続の有効性を確認する方法は、特にプロジェクトがビジネス処理にRedisに依存している場合によく見られます。以下は...

Laravelデータベースの移行の遭遇重複クラス定義:複製の移行ファイルとクラス名の競合を複製する方法は? Laravelデータベースの移行の遭遇重複クラス定義:複製の移行ファイルとクラス名の競合を複製する方法は? Apr 01, 2025 pm 12:21 PM

Laravelデータベースの移行中にクラス定義を複製する問題が発生します。データベースの移行にLaravelフレームワークを使用する場合、開発者は「クラスが使用されています...

Laravelは紹介例 Laravelは紹介例 Apr 18, 2025 pm 12:45 PM

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

See all articles