検索
ホームページバックエンド開発PHPの問題PHP を使用して 1 対多の相関クエリを実行する方法

PHP をデータベース操作に使用する場合、多くの場合、1 対多の相関クエリを実行する必要があります。この種のクエリでは、1 つのテーブルのデータを別のテーブルの複数のデータに関連付けることができます。 PHP では、1 対多のリレーショナル クエリは通常 2 次元配列になります。この配列では、各要素がメイン テーブル レコードを表し、対応する値が複数の関連テーブルのレコードになります。

この記事では、PHP を使用して 1 対多の関連クエリを実行し、2 次元配列の結果を取得する方法を紹介します。

1. 1 対多のリレーショナル クエリとは何ですか?

データベースでは、2 つのテーブル間に主キーと外部キーの関係がある場合、1 対多の関連付けクエリを実行できます。この関係では、1 つのテーブルの 1 つのレコードが別のテーブルの複数のレコードに対応します。

たとえば、「生徒テーブル」と「得点テーブル」があり、「生徒テーブル」の各生徒は複数の「得点テーブル」のレコードに対応しています。この関係は、以下に示すように、主キーと外部キーを使用してバインドできます。

CREATE TABLE `student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `score` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `student_id` int(11) DEFAULT NULL,
  `score` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `student_id` (`student_id`),
  CONSTRAINT `score_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

「Student Table」では、各レコードに一意の識別子 ID と名前 NAME が含まれます。 「スコア テーブル」では、各レコードには同じ一意の識別子 ID と、レコードがどの生徒に属しているかを表す対応する STUDENT_ID が含まれており、さらに、生徒のスコアを表す SCORE フィールドもあります。

2. 1 対多の相関クエリを実行するにはどうすればよいですか?

PHP では、JOIN キーワードを使用して 1 対多の関連クエリを実行できます。 JOIN は、2 つ以上のテーブルの同じ列を結合して大きなテーブルを生成するために使用される SQL のキーワードです。

上記の例で、student テーブルを成績テーブルに関連付ける場合は、次の SQL ステートメントを使用できます。

SELECT student.*, score.score
FROM student
LEFT JOIN score ON student.id = score.student_id;

このステートメントでは、最初に Student テーブルのすべてのフィールドを選択します。 table を作成し、LEFT JOIN および ON キーワードを使用してスコア テーブルと学生テーブルを接続します。接続の条件は、student テーブルの ID フィールドが成績テーブルの STUDENT_ID フィールドと等しいことです。最後に、SELECT ステートメントで表示する列を選択し、2 次元配列の結果を取得します。

PHP の PDO オブジェクトでは、クエリ メソッドを使用して上記の SQL ステートメントを実行し、fetchAll メソッドを使用して 2 次元配列の結果を取得できます。コードでは、最初に PDO オブジェクトを作成し、次に query メソッドを使用して SQL ステートメントを実行し、最後に fetchAll メソッドを使用して結果を取得します。

3. 1 対多の関連付けクエリ結果を 2 次元配列に処理するにはどうすればよいですか?

1 対多の関連付けクエリを実行する場合、複数のテーブルのデータを 2 次元配列の結果に結合する必要があります。この 2 次元配列の各要素はメイン テーブルのレコードを表し、対応する値は複数の関連テーブルのレコードになります。

以下は、1 対多の関連付けクエリ結果を 2 次元配列に処理する方法です:

$db = new PDO('mysql:host=localhost;dbname=mydb', 'myuser', 'mypassword');
$stmt = $db->query('SELECT student.*, score.score
                    FROM student
                    LEFT JOIN score ON student.id = score.student_id');
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);

上記のコードでは、まず空の配列 $data を作成します。 2 次元配列の最終的な結果として使用されます。次に、foreach ループを使用してクエリ結果の各レコードを走査し、各レコードの主キー ID を $id 変数に保存します。

次に、$data 配列に主キー $id を持つ要素が既に存在するかどうかを確認します。存在しない場合は、要素が $data 配列に挿入され、主キーに関連するすべてのレコードを保持するために「scores」という名前の空の配列が作成されます。すでに存在する場合は挿入する必要はなく、既存の要素が直接使用されます。

レコードを走査するときに、「スコア テーブル」内のレコードが見つかった場合は、そのレコードの SCORE フィールドをスコア配列に追加します。 1 つのメイン テーブル レコードは複数の関連テーブル レコードに対応するため、スコア配列は 2 次元配列として保存する必要があります。

ループが終了すると、最終的な 2 次元配列の結果が $data 配列に格納されます。各要素はメイン テーブル レコードを表し、対応する値は関連テーブル内の複数のレコードです。

4. 例

以下は、1 対多の関連付けクエリを実行し、結果を 2 次元配列に処理する方法を示す完全な例です。 ##上記の例では、まず PDO オブジェクトを作成し、クエリ メソッドを使用して SQL ステートメントを実行します。次に、fetchAll メソッドを使用してクエリ結果を取得します。

次に、foreach ループを使用してクエリ結果の各レコードを走査し、2 次元配列に処理します。最後に、print_r 関数を使用して結果を出力します。

5. 結論

この記事では、PHP で 1 対多の関連クエリを実行し、結果を 2 次元配列に処理する方法を紹介します。結果を処理するときは、ループを使用してクエリ結果を走査し、それらを 2 次元配列に変換する必要があります。すべてのレコードを処理した後、各要素がメイン テーブル レコードを表し、対応する値が複数の関連テーブルのレコードである 2 次元配列の結果を取得できます。

以上がPHP を使用して 1 対多の相関クエリを実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
酸とベースデータベース:違いとそれぞれを使用するタイミング。酸とベースデータベース:違いとそれぞれを使用するタイミング。Mar 26, 2025 pm 04:19 PM

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

PHPセキュアファイルアップロード:ファイル関連の脆弱性の防止。PHPセキュアファイルアップロード:ファイル関連の脆弱性の防止。Mar 26, 2025 pm 04:18 PM

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

PHP入力検証:ベストプラクティス。PHP入力検証:ベストプラクティス。Mar 26, 2025 pm 04:17 PM

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

PHP APIレート制限:実装戦略。PHP APIレート制限:実装戦略。Mar 26, 2025 pm 04:16 PM

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

PHPパスワードハッシュ:password_hashおよびpassword_verify。PHPパスワードハッシュ:password_hashおよびpassword_verify。Mar 26, 2025 pm 04:15 PM

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

OWASPトップ10 PHP:共通の脆弱性を説明し、軽減します。OWASPトップ10 PHP:共通の脆弱性を説明し、軽減します。Mar 26, 2025 pm 04:13 PM

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

PHP XSS予防:XSSから保護する方法。PHP XSS予防:XSSから保護する方法。Mar 26, 2025 pm 04:12 PM

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

PHPインターフェイスvs抽象クラス:それぞれを使用する時期。PHPインターフェイスvs抽象クラス:それぞれを使用する時期。Mar 26, 2025 pm 04:11 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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

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

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。