検索
ホームページバックエンド開発PHPチュートリアルLaravelスキル クエリビルダーオーバーレイチェーン呼び出しメソッド解説

この記事では主に、laravel スキルにおけるクエリ ビルダー クエリ ビルダー オーバーレイ チェーン コールに関する関連情報を紹介します。この記事ではサンプル コードを通じて詳細に紹介しており、あらゆる人の学習や仕事に一定の参考学習価値があります。必要な場合は、下記をご覧ください。

クエリ ビルダーの概要

Laravel クエリ ビルダー (クエリ ビルダー) は、データベース検索を確立および実行するための便利で流暢なインターフェイスを提供します。

##PDO パラメーター バインディングを使用して、アプリケーションを SQL インジェクションから保護します。したがって、受信パラメータで特殊文字をエスケープする必要はありません。

基本的に、すべてのデータベース操作が満たされ、サポートされているすべてのデータベース システムで実行できます

はじめに

今日は、laravel クエリコンストラクターの小技を紹介します。公式ドキュメントのサンプルには詳しく記載されていません。高度なスキルではありません。いいえ、知っている学生は見てみてください。

ビジネス コードでは、さまざまな条件に基づいてクエリが実行されることがよくあります。簡単な例として、新しい順に並べられたユーザー リストをクエリしたいとします。条件としてステータスとタイプが存在する場合があります。

これは最初に私が書いた方法です

 if($status && $type) {
 $users = User::where('status', $status)->where('type', $type)->latest()->get();
 } else if ($status) {
 $users = User::where('status', $status)->latest()->get(); 
 } else if ($type) {
 $users = User::where('status', $type)->latest()->get();
 } else {
 $users = User::latest()->get(); 
 }

このコードは本当に醜いです、 -> などの一般的なコードがたくさんあります;latest() ->get() を 4 回記述します。製品が「今日は順番に並べ替えたい」と指示した場合、4 か所を変更する必要があります。エディターを使用して簡単に変更できますが、これは最も単純な例にすぎないことを知っておく必要があります。

ドキュメントを読むと、条件判断のための when メソッドがありますが、クロージャの束は理想的ではありません。もっとエレガントな書き方があるに違いないと強く信じていたので、stackoverflow で検索したところ、案の定、全能の Waiguoren が答えをくれました。

改善された記述方法:

 $query = User::query();
 // 如果用DB: $query = DB::table('user'); 
 if ($status) {
  $query->where('status', $status);
 }
 if ($type) {
  $query->where('type', $type);
 } 
 $users = $query->latest()->get();

変数を使用してクエリ コンストラクター インスタンスを保存し、それに制約を重ねて、最後にコレクションを取得します。公開部分が最初と最後に置かれていて構成が明確ですが、判断なのでしょうか?

また、 $query をパラメータとしてメソッドまたは関数に渡し、共通のロジックをカプセル化して複数の呼び出しを容易にすることもできます。

 function foo($query) {
  $query->with(['girl', 'gay'])
    ->latest()
    ->get();
 } 
 $query = User::query();
 $users = foo($query);

この書き方の注意点は、where on $queryなどの制約メソッドを呼び出すとクエリが変更されてしまうため、場合によっては事前にクエリのクローンを作成しておく必要があることです。

たとえば、タイプ 1 とタイプ 2 のユーザーを同時に取得したいとします。

 $query_1 = User::query();
 $query_2 = clone $query_1; 
 $users_1 = $query_1->where('type', 1)->latest()->get();
 $users_2 = $query_2->where('type', 2)->latest()->get();
 // 错误 $users_2 = $query_1->where('type', 1)->latest()->get();
 // 这样写得到得是type = 1 and $type = 2

これは書かれていませんが、 laravel ドキュメントの例で説明されていますが、

DB ファサードのテーブル メソッドを使用してクエリを開始できます。このテーブル メソッドはクエリ テーブルのクエリ ビルダー インスタンスを返すため、クエリ時にさらに多くの制約を連鎖させ、get メソッドを使用して最終結果を取得できます


余談

Previous I Baidu しか知らないプログラマは要らない、という先輩の意見も聞きましたが、当時は Google を使っていなかったので、すべての検索エンジンではなく、非常に見栄を張ったものだと感じていました。今では、Baidu しか知らない人と仕事をしたくありません。Baidu は単なる広告検索であり、検索結果はすべてナンセンスです。

Google と stackoverflow は本当に優れています。その多くは豊富な知識と専門的な回答を持っています。コンピューターの歴史からオペレーティング システム、データベース、さまざまなプログラミング言語に至るまで、多くのバグのデバッグに役立ちました。セグメント違反でこのように宣伝するのは悪いことですか? 逃げてください!

#概要参考:


    使用して複数の where 句クエリを作成する方法Laravel Eloquent? - stackoverflow
  1. Model::query - laravelAPI

興味があるかもしれない記事:

フィボナッチ数列を実装するための PHP コードの共有


二分法に基づく配列検索関数の PHP 実装の例説明


phpのクラスとオブジェクトの詳しい説明


以上がLaravelスキル クエリビルダーオーバーレイチェーン呼び出しメソッド解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
負荷分散がセッション管理にどのように影響し、それに対処するかを説明します。負荷分散がセッション管理にどのように影響し、それに対処するかを説明します。Apr 29, 2025 am 12:42 AM

負荷分散はセッション管理に影響しますが、セッションの複製、セッションの粘着性、集中セッションストレージで解決できます。 1。セッションレプリケーションサーバー間のセッションデータをコピーします。 2。セッションスティンネスは、ユーザーリクエストを同じサーバーに指示します。 3.集中セッションストレージは、Redisなどの独立したサーバーを使用してセッションデータを保存してデータ共有を確保します。

セッションロックの概念を説明します。セッションロックの概念を説明します。Apr 29, 2025 am 12:39 AM

SESSIONLOCKINGISATECHNIQUESTOESUREAUSER'SSESSIONREMAINSEXCLUSIVETOONEUSATIME.ITISCRUCIALFORPREVENTINGDATACORTIONANDSECURITYBREACHESINMULTI-USERAPPLICATIONS.SESSIONLOCKINGISISIMPLEMENTEDUSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGROCKINGSMECHANISMなど

PHPセッションの選択肢はありますか?PHPセッションの選択肢はありますか?Apr 29, 2025 am 12:36 AM

PHPセッションの代替品には、Cookie、トークンベースの認証、データベースベースのセッション、Redis/Memcachedが含まれます。 1.Cookiesは、クライアントにデータを保存することによりセッションを管理します。 2.トークンベースの認証はトークンを使用してユーザーを検証します。これは非常に安全ですが、追加のロジックが必要です。 3.Databaseベースのセッションは、データベースにデータを保存します。これは、スケーラビリティが良好ですが、パフォーマンスに影響を与える可能性があります。 4. Redis/Memcachedは分散キャッシュを使用してパフォーマンスとスケーラビリティを向上させますが、追加のマッチングが必要です

PHPのコンテキストで「セッションハイジャック」という用語を定義します。PHPのコンテキストで「セッションハイジャック」という用語を定義します。Apr 29, 2025 am 12:33 AM

SessionHijackingとは、ユーザーのSessionIDを取得してユーザーになりすましている攻撃者を指します。予防方法には、次のものが含まれます。1)HTTPSを使用した通信の暗号化。 2)SessionIDのソースの検証。 3)安全なSessionID生成アルゴリズムの使用。 4)SessionIDを定期的に更新します。

PHPの完全な形式は何ですか?PHPの完全な形式は何ですか?Apr 28, 2025 pm 04:58 PM

この記事では、PHPについて説明し、その完全なフォーム、Web開発での主要な使用、PythonとJavaとの比較、および初心者の学習のしやすさについて説明します。

PHPはフォームデータをどのように処理しますか?PHPはフォームデータをどのように処理しますか?Apr 28, 2025 pm 04:57 PM

PHPは、$ \ _ postおよび$ \ _を使用してフォームデータを処理し、検証、消毒、安全なデータベースインタラクションを通じてセキュリティを確保します。

PHPとASP.NETの違いは何ですか?PHPとASP.NETの違いは何ですか?Apr 28, 2025 pm 04:56 PM

この記事では、PHPとASP.NETを比較して、大規模なWebアプリケーション、パフォーマンスの違い、セキュリティ機能への適合性に焦点を当てています。どちらも大規模なプロジェクトでは実行可能ですが、PHPはオープンソースであり、プラットフォームに依存しませんが、ASP.NET、

PHPはケースに敏感な言語ですか?PHPはケースに敏感な言語ですか?Apr 28, 2025 pm 04:55 PM

PHPの症例感度は変化します:関数は鈍感であり、変数とクラスは感度があります。ベストプラクティスには、一貫した命名と、比較のためにケース非感受性関数を使用することが含まれます。

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

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

SecLists

SecLists

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール