[ { "id":1, "name":"test", "department_id":1, "department":{ "id":1, "name":"测试部门" } } ]方法 1: ループ クエリ
- ユーザー リストのクエリ
- ユーザー リストをループして、対応する部門情報をクエリします
$users = $db->query('SELECT * FROM `user`');foreach($users as &$user) { $users['department'] = $db->query('SELECT * FROM `department` WHERE `id` = '.$user['department_id']); }
方法二:连表
通过连表查询用户和部门数据
处理返回数据
$users = $db->query('SELECT * FROM `user` INNER JOIN `department` ON `department`.`id` = `user`.`department_id`');// 手动处理返回结果为需求结构
该方法其实也有局限性,如果 user 和 department 不在同一个服务器是不可以连表的。
方法三:1+1查询
该方法先查询1次用户列表
取出列表中的部门ID组成数组
查询步骤2中的部门
合并最终数据
代码大致如下:
$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 サイトの他の関連記事を参照してください。

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

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

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

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

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

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

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

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


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

Dreamweaver Mac版
ビジュアル Web 開発ツール

WebStorm Mac版
便利なJavaScript開発ツール

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

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