目次
#ヘビの命名属性" >#ヘビの命名属性
モデルにカスタム値を追加する" >モデルにカスタム値を追加する
modelKeys 方法
ホームページ PHPフレームワーク Laravel コードの可読性を向上させるための Laravel Eloquent の 6 つのヒント!

コードの可読性を向上させるための Laravel Eloquent の 6 つのヒント!

Nov 15, 2022 pm 08:07 PM
php laravel

この記事では、コードの可読性を向上させるための 6 つの Laravel Eloquent のヒントをまとめて共有します。

コードの可読性を向上させるための Laravel Eloquent の 6 つのヒント!

Eloquent は、Laravel によってデフォルトで使用される ORM です。アクティブ記録モードが使用されます。より簡単な方法でデータベースを操作できるようになります。個々のモデルは、操作可能なデータベース内のテーブルを表します。この記事では、コードを改善するためにあまり知られていない隠された秘密、メソッド、プロパティを多かれ少なかれ紹介します。

ヘビの命名属性は興味深い属性です。コードの内容を見てみましょう:

/**
 * 指示是否在数组上使用蛇形大小写属性。
 *
 * @var bool
 */
public static $snakeAttributes = true;
ログイン後にコピー

このプロパティへのアクセス方法を変更するためにこのプロパティを誤って使用することがよくあります。多くの人は、このプロパティを変更すると、キャメルケースの注釈を使用してプロパティに簡単にアクセスできると信じています。しかし実際にはそうではありません。使用しないことを強くお勧めします。モデルを配列として出力する場合、属性をキャメルケースにするかスネークケースにするかを定義するだけです。

キャメルケースに基づいて名前を付けたい場合は、Kirk Bushell のパッケージ

Eloquence by Kirk Bushell をチェックすることをお勧めします。

Pagination

Laravel の Eloquent ORM を使用している場合、これは朗報です。すぐに使用できるページネーション方法を提供します。次のような記述に慣れているかもしれません:

$comments = Comment::paginate(20);
ログイン後にコピー

この方法を使用すると、1 ページあたり 20 エントリでコメント モデルをページ分割できます。この値を変更して、ページごとに表示されるアイテムの数を定義します。何も指定しない場合は、デフォルト値の 15 が適用されます。

コメントをサイト上の複数の場所に表示したいとします。 1 ページあたり常に 30 件のコメントがあります。どこにでもパラメーター 30 を渡す必要がある場合、それは問題です。したがって、新しいデフォルト値をモデルに直接設定できます。

protected $perPage = 30;
ログイン後にコピー

Eloquent には「アクセサー」と呼ばれる強力な機能があります。この機能を使用すると、モデルに存在しないカスタム フィールドをモデルまたはテーブルに追加できます。既存の値を使用するか、まったく新しい値を定義するかは関係なく、いつでもフォールバックできます。以下はアクセサーがどのように機能するかの例です。

user という名前のモデルがあるとします。これに FullName アクセサーを追加します。

function getFullNameAttribute() {
    return sprintf('%s %s', $this->first_name, $this->last_name);
}
ログイン後にコピー

これで、次のように、ポスト モデルの

full_name 属性にアクセスできるようになります。

User::latest()->first()->full_name;
ログイン後にコピー

オブジェクト (コレクションなど) が返された場合、このプロパティはユーザー モデルにアタッチされません。 protected

$appends 属性をモデルに追加します。 1 つ以上のフィールドを含む配列を受け入れます。これらのフィールドは今後自動的に追加されます。次のように書くだけです:

protected $appends = ['full_name'];
ログイン後にコピー

存在しない列にミューテーター (プロパティ セッター) を追加します

ミューテーターはゲッターの反対です。これを使えば本当に面白いことができます。たとえば、さまざまな種類の入力を変換します。詳しく教えてください。あるタイプの期間を保存したいとします。一般に、常に可能な限り最小単位を保存します。私たちの場合は秒です。 UX 上の理由から、ユーザーは、ある場所では分、別の場所では時間など、秒を入力することを好みません。これはすべてすぐに解決できます。

class Video extends Model
{
    public function setDurationInMinutes($value)
    {
        $this->attributes['duration_in_seconds'] = $value * 60;
    }

    public function setDurationInHours($value)
    {
        $this->attributes['duration_in_seconds'] = $value * 60 * 60;
    }
}
ログイン後にコピー

上記のコードは、データ テーブル自体に存在しないフィールドを使用できることを意味します。

duration_in_ minutes
フィールドは model で使用されていますが、バックグラウンドでは duration_in_seconds を使用して更新するか、存在しないフィールド duration_in_hours を使用することもできます。 。このロジックに従って、コントローラー内で次のように呼び出します。

class AnyController
{
    public function store()
    {
        $video->update([
            'title' => request('title'),
            'duration_in_minutes' => request('duration_in_minutes'),
        ]);
    }
}
ログイン後にコピー

これにより、コントローラー内で計算を行う時間を節約できます。特定の計算を実行するときに、単純に存在しない列を使用して ## を使用できます。 #mutator

その結果を正しいフィールドにマップします。 熱心な読み込み: $with で

#人間関係について話しましょう。デフォルトでは、Laravel は遅延読み込みを使用します。これは人間関係の観点から何を意味しますか?遅延読み込みの利点は、すべてのデータを保持する必要がなく、必要なときにデータをロードできるため、メモリを節約できることです。次のようになります。

$comments = Comment::all();
foreach ($comments as $comment) {
    echo $comment->user->name;
}
ログイン後にコピー

上記の例では、すべてのコメント データを取得します。次に、コメントを繰り返し処理し、各コメントのユーザー名を表示します。このコードには何も問題はなく、正常に動作しますが、問題が発生しました。遅延読み込みにより、ユーザー名を出力する場合にのみユーザーを取得するクエリが実行されるようになりました。

最初の N 1 の質問へようこそ。なぜN1なのか? N は常にレビューの数で、1 はレビューを取得するためのクエリです。たとえば、レビューが 500 件ある場合、すべてのレビューを取得するクエリが 1 回トリガーされ、その後、対応するユーザーごとのレビューを取得するクエリが 1 回トリガーされます。つまり、1 つのクエリに対して 500 です。これは、アノテーションの数が増加すると、クエリの数も増加することを意味します。

これを防ぐために、eagerloadingという方法があります。

$comments = Comment::with('user')->get();
foreach ($comments as $comment) {
    echo $comment->user->name;
}
ログイン後にコピー

这会以两个查询结束。第一个查询获取所有注释,第二个查询立即获取所有关联用户。在后台,会发生以下情况(简化版SQL):

SELECT id, user_id, body FROM comments;
SELECT name FROM users WHERE user_id IN (1,2,3,4,5...);
ログイン後にコピー

不论是 10、500 还是 10000 条评论数据都不重要,我们都依旧只执行两次SQL查询。

好了,你现在已经看到如何使用渴求式加载了。但只限于如何手动使用。你还可以将整个过程自动化,以便某些关联关系总是自动通过渴求式方式加载。为此,需要给模型设定一个属性。

protected $with = [];
ログイン後にコピー

我们可以在Comment model简单设置 protected $with = ['user'];, 从现在起,user在任何时候都会自动加载。

我们还有很多种渴求式加载,有仅加载特定列、嵌套即时加载、多个即时加载等等。更多详情请Laravel文档或深入核心。

modelKeys 方法

有的时候需要查询所有的主键 ID, 查询是否复杂并不重要,大多数人可能会像这样做:

User::all()->pluck('id');
ログイン後にコピー

这个操作很 nice,但是返回的是一个集合,想要转换成数组的话可以使用 toArray()

User::all()->pluck('id')->toArray();
ログイン後にコピー

大多数情况下,上面的操作的可以简化成这样:

User::all()->modelKeys();
ログイン後にコピー

这种方式返回一个数组。重要的是这个方法并不会总是返回 id。 顾名思义,他是以数组的形式返回所有模型主键。主键默认是id,同时也可以在模型中定义主键名。

protected $primaryKey = 'id';
ログイン後にコピー

原文地址:https://laravel-news.com/6-eloquent-secrets

译文地址:https://www.php.cn/link/c7decb5ce28209911b545d0b1059c5e3

【相关推荐:laravel视频教程

以上がコードの可読性を向上させるための Laravel Eloquent の 6 つのヒント!の詳細内容です。詳細については、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)

PHPとPython:2つの一般的なプログラミング言語を比較します PHPとPython:2つの一般的なプログラミング言語を比較します Apr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHP:Web開発の重要な言語 PHP:Web開発の重要な言語 Apr 13, 2025 am 12:08 AM

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHPの現在のステータス:Web開発動向を見てください PHPの現在のステータス:Web開発動向を見てください Apr 13, 2025 am 12:20 AM

PHPは、現代のWeb開発、特にコンテンツ管理とeコマースプラットフォームで依然として重要です。 1)PHPには、LaravelやSymfonyなどの豊富なエコシステムと強力なフレームワークサポートがあります。 2)パフォーマンスの最適化は、Opcacheとnginxを通じて達成できます。 3)PHP8.0は、パフォーマンスを改善するためにJITコンパイラを導入します。 4)クラウドネイティブアプリケーションは、DockerおよびKubernetesを介して展開され、柔軟性とスケーラビリティを向上させます。

PHP対その他の言語:比較 PHP対その他の言語:比較 Apr 13, 2025 am 12:19 AM

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHPの永続的な関連性:それはまだ生きていますか? PHPの永続的な関連性:それはまだ生きていますか? Apr 14, 2025 am 12:12 AM

PHPは依然として動的であり、現代のプログラミングの分野で重要な位置を占めています。 1)PHPのシンプルさと強力なコミュニティサポートにより、Web開発で広く使用されています。 2)その柔軟性と安定性により、Webフォーム、データベース操作、ファイル処理の処理において顕著になります。 3)PHPは、初心者や経験豊富な開発者に適した、常に進化し、最適化しています。

PHP:多くのウェブサイトの基礎 PHP:多くのウェブサイトの基礎 Apr 13, 2025 am 12:07 AM

PHPが多くのWebサイトよりも優先テクノロジースタックである理由には、その使いやすさ、強力なコミュニティサポート、広範な使用が含まれます。 1)初心者に適した学習と使用が簡単です。 2)巨大な開発者コミュニティと豊富なリソースを持っています。 3)WordPress、Drupal、その他のプラットフォームで広く使用されています。 4)Webサーバーとしっかりと統合して、開発の展開を簡素化します。

PHP対Python:コア機能と機能 PHP対Python:コア機能と機能 Apr 13, 2025 am 12:16 AM

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

PHPの目的:動的なWebサイトの構築 PHPの目的:動的なWebサイトの構築 Apr 15, 2025 am 12:18 AM

PHPは動的なWebサイトを構築するために使用され、そのコア関数には次のものが含まれます。1。データベースに接続することにより、動的コンテンツを生成し、リアルタイムでWebページを生成します。 2。ユーザーのインタラクションを処理し、提出をフォームし、入力を確認し、操作に応答します。 3.セッションとユーザー認証を管理して、パーソナライズされたエクスペリエンスを提供します。 4.パフォーマンスを最適化し、ベストプラクティスに従って、ウェブサイトの効率とセキュリティを改善します。

See all articles