検索
ホームページ毎日のプログラミングmysqlの知識データベースの N+1 クエリの問題を解決する

データベースの N+1 クエリの問題を解決する

#要件

データ テーブルは次のとおりです:

部門テーブル

#|id|name|

user table

|id|name|payment_id|

要件は、次の構造を持つデータを取得することです:

[
    {        "id":1,        "name":"test",        "department_id":1,        "department":{            "id":1,            "name":"测试部门"
        }
    }
]

方法 1: ループ クエリ

  1. ユーザー リストのクエリ

  2. ユーザー リストをループして、対応する部門情報をクエリします

  3. $users = $db->query('SELECT * FROM `user`');foreach($users as &$user) {
        $users['department'] = $db->query('SELECT * FROM `department` WHERE `id` = '.$user['department_id']);
    }
このメソッドのクエリの数は: 1 N (1 クエリ リスト、N クエリ部門)、パフォーマンスは最低であり、推奨されません。

方法二:连表

  1. 通过连表查询用户和部门数据

  2. 处理返回数据

$users = $db->query('SELECT * FROM `user` INNER JOIN `department` ON `department`.`id` = `user`.`department_id`');// 手动处理返回结果为需求结构

该方法其实也有局限性,如果 user 和 department 不在同一个服务器是不可以连表的。

方法三:1+1查询

  1. 该方法先查询1次用户列表

  2. 取出列表中的部门ID组成数组

  3. 查询步骤2中的部门

  4. 合并最终数据

代码大致如下:

$users = $db->query('SELECT * FROM `user`');
$departmentIds =[ ];foreach($users as $user) {    if(!in_array($user['department_id'], $departmentIds)) {
        $departmentIds[] = $user['department_id'];
    }
}
$departments = $db->query('SELECT * FROM `department` WHERE id in ('.join(',',$department_id).')');
$map = []; // [部门ID => 部门item]foreach($departments as $department) {
    $map[$department['id']] = $department;
}foreach($users as $user) {
    $user['department'] = $map[$user['department_id']] ?? null;
 }

该方法对两个表没有限制,在目前微服务盛行的情况下是比较好的一种做法。

更多MySQL相关技术文章,请访问MySQL教程栏目进行学习!

以上がデータベースの N+1 クエリの問題を解決するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
不正アクセスに対してMySQLサーバーをどのように保護しますか?不正アクセスに対してMySQLサーバーをどのように保護しますか?Mar 20, 2025 pm 03:20 PM

この記事では、パスワード管理を介した不正アクセスに対するMySQLサーバーのセキュリティ、リモートアクセスの制限、暗号化、および定期的な更新について説明します。また、セキュリティを強化するために、疑わしい活動の監視と検出をカバーしています。

役割を使用してユーザー許可を管理しますか?役割を使用してユーザー許可を管理しますか?Mar 20, 2025 pm 03:19 PM

この記事では、役割を使用してユーザー許可を効率的に管理し、役割の定義、許可の割り当て、動的調整の詳細を管理します。ロールベースのアクセス制御のベストプラクティスと、役割がユーザー管理ACRをどのように単純化するかを強調しています

MySQLでユーザーアカウントのパスワードをどのように設定しますか?MySQLでユーザーアカウントのパスワードをどのように設定しますか?Mar 20, 2025 pm 03:18 PM

この記事では、MySQLユーザーアカウントのパスワード、パスワードセキュリティのベストプラクティス、リモートパスワードの変更、パスワードポリシーのコンプライアンスの確保の方法について説明します。

MySQLのさまざまなタイプの特権は何ですか?MySQLのさまざまなタイプの特権は何ですか?Mar 20, 2025 pm 03:16 PM

記事では、MySQLの特権について説明します:グローバル、データベース、テーブル、列、ルーチン、およびプロキシユーザータイプ。それは、安全な管理のための許可、特権を取り消し、ベストプラクティスを説明しています。主張するリスクが強調されています。

Grant Statementを使用してユーザーに特権をどのように付与しますか?Grant Statementを使用してユーザーに特権をどのように付与しますか?Mar 20, 2025 pm 03:15 PM

この記事では、SQLでの助成金ステートメントの使用を説明して、特定のデータベースオブジェクトのユーザーや役割の選択、挿入、更新などのさまざまな特権を割り当てます。また、Revoke Statementでの取り消し特権をカバーし、Privilegを付与します

Createユーザーステートメントを使用してMySQLでユーザーをどのように作成しますか?Createユーザーステートメントを使用してMySQLでユーザーをどのように作成しますか?Mar 20, 2025 pm 03:14 PM

記事では、MySQLユーザーの作成を作成し、ユーザーステートメントの作成、特権の割り当て、パスワードの設定、ユーザー名の選択について説明します。

ストアドプロシージャと機能を実行するための許可をどのように許可しますか?ストアドプロシージャと機能を実行するための許可をどのように許可しますか?Mar 20, 2025 pm 03:12 PM

記事では、安全なマルチユーザーデータベース管理のためのSQLコマンドとベストプラクティスに焦点を当てた、ストアドプロシージャと機能に関する実行権限を付与することについて説明します。

別のストアドプロシージャまたは機能からストアドプロシージャをどのように呼び出しますか?別のストアドプロシージャまたは機能からストアドプロシージャをどのように呼び出しますか?Mar 20, 2025 pm 03:11 PM

この記事では、SQL Serverに焦点を当てた、他のストアドプロシージャまたは関数内からのストアドプロシージャの呼び出しについて説明します。構文、モジュール性とセキュリティなどの利点、ネストされた手順のエラー処理、設計上の考慮事項をカバーします。

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

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。