Laravel は、そのシンプルさと使いやすさで人気のある PHP Web フレームワークです。 Laravel フレームワークは、優れた Eloquent ORM の実装で知られています。これは、PHP を使用したデータベース モデルの定義をサポートし、これらのモデルに基づいた簡単なデータベース インタラクションを提供するオブジェクト リレーショナル ミニ マッピングです。
この記事では、Laravel Eloquent を使用してデータベースと迅速かつ確実に対話するモデルを構築する方法を詳しく紹介します。
Laravel Eloquent とは
Eloquent ORM は、Laravel フレームワークに組み込まれた ORM システムです。これにより、MySQL ステートメントでデータを直接操作するのではなく、PHP を使用してデータベースと対話できるようになります。 Eloquent は一連のデータ テーブルをオブジェクトにマップするため、SQL ステートメントを直接実行せずに、データ テーブル内の各フィールドに名前を付けて操作できます。
Laravel Eloquent ORM を使用するには、以下に示すように、データベース モデルを構築する前にデータベース接続を構成する必要があります。
<?php use IlluminateSupportFacadesDB; $connection = DB::connection(); $name = $connection->getDatabaseName();
一般に、Laravel フレームワークは .env
ファイルにデータベース接続をすでに構成していますが、ローカル開発では通常、デフォルトの接続を維持するだけで済みます。
Laravel Eloquent を使用してモデルを構築する方法
Laravel Eloquent ORM は、複雑な SQL ステートメントを作成せずにモデルを定義するためのシンプルかつ強力な方法を提供します。
Laravel では、各 Eloquent モデルはデータベース テーブルに関連付けられます。 php 職人
コマンドを使用してデータベース移行ファイルを作成し、次に php 職人 make:model
コマンドを使用して Eloquent モデルを作成できます。
次の例は、モデルの作成方法を示しています:
php artisan make:model Example
これにより、アプリ ディレクトリに Example.php ファイルが作成されます。具体的なコードは次のとおりです:
<?php namespace App; use IlluminateDatabaseEloquentModel; class Example extends Model { // }
この単純なモデルを使用して、データ テーブルの定義とモデル化を開始できます。具体的なモデリングは次のとおりです:
Schema::create(`example`, function ($table) { $table->increments(`id`); $table->string(`title`); $table->string(`body`); $table->timestamps(); });
モデルを定義した後、Eloquent のクエリ ビルダーを使用してクエリを構築できます。以下はLaravel Eloquent クエリの例:
$example = Example::find(1);
このクエリでは、Example::find(1)
はデフォルトのテーブル example
内のレコードを読み取り、 AppExample
Model インスタンス。このモデル インスタンスでは、内部関数またはプロパティを実行できます。例:
$title = $example->title;
上記のコードは、テーブル内の ID 1 のレコードのタイトル列の値を出力します。
データテーブルモデルへの関連付けの追加
Laravel Eloquent ORM では、次の 2 つのモデル間の関連付けなど、関連付け関係を追加することでデータ モデル間の関係を表現できます:
class Country extends Model { public function user() { return $this->hasMany(User::class); } } class User extends Model { public function country() { return $this->belongsTo(Country::class); } }
このモデルでは、1 つの国に複数のユーザーが存在できるため、 Country
ModelhasMany
がユーザー モデルに関連付けられますが、一方、ユーザーは 1 つの国からのみアクセスできます。したがって、モデル User
は、belongsTo
メソッドを使用して国モデルに属します。
これらの関係を定義すると、クエリ時に with
メソッドを使用して、対応する関連モデルを簡単に取得できます。たとえば、次のようになります。
$countries = Country::with('user')->get();
上記のクエリでは、 Country::with('user')
Country::user()
で定義された関連付けのユーザー レコードを返します。これらのコレクションには、返されたコレクション内でアクセスできます。例:
foreach ($countries as $country) { foreach ($country->user as $user) { echo $user->name; } }
summary
Laravel Eloquent ORM は、Laravel フレームワークの最高の機能の 1 つであり、データベースとのやり取りの複雑さを簡素化します。開発者向け。データベース接続を設定し、モデルを作成し、関係を定義することで、データベースと簡単にやり取りしたり、データベースからデータを取得したりできます。 Laravel を使用する場合は、Laravel Eloquent ORM を使用してデータベース モデルをより効率的かつ合理的に構築することを忘れないでください。
以上がLaravel 開発: Laravel Eloquent を使用してモデルを構築するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。