ホームページ > データベース > mysql チュートリアル > 共有 ID を使用して 4 つの SQL テーブルを効率的に結合するにはどうすればよいですか?

共有 ID を使用して 4 つの SQL テーブルを効率的に結合するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-14 07:27:44
オリジナル
494 人が閲覧しました

How to Efficiently Join Four SQL Tables Using Shared IDs?

共有 ID を使用した複数の SQL テーブルの接続

リレーショナル データベースを操作するには、多くの場合、複数のテーブルのデータを結合する必要があります。これには、共通の列に基づいてテーブルを結合することが含まれます。 このガイドでは、それぞれの ID を使用して 4 つのテーブル (TableA、TableB、TableC、および TableD) を効果的に結合する方法を説明します。

テーブル構造:

  • テーブル A: aID |名前A | dID
  • テーブル B: bID |名前B | cID |補助
  • テーブル C: cID |名前C |日付
  • テーブルD: dID |名前D

初期結合 (テーブル A、B、および C):

テーブル B を介してテーブル A と C を結合する一般的な方法では、共有の「aID」列と「cID」列を使用します。

<code class="language-sql">SELECT TableA.*, TableB.*, TableC.*
FROM (TableB INNER JOIN TableA ON TableB.aID = TableA.aID)
INNER JOIN TableC ON TableB.cID = TableC.cID
WHERE DATE(TableC.date) = DATE('now()')</code>
ログイン後にコピー

TableD を結合に追加します:

TableD を最初のクエリに直接結合すると、共有列がないため問題が発生します。 解決策は、別の結合条件を追加することです:

<code class="language-sql">SELECT TableA.*, TableB.*, TableC.*, TableD.*
FROM TableA
JOIN TableB ON TableB.aID = TableA.aID
JOIN TableC ON TableC.cID = TableB.cID
JOIN TableD ON TableD.dID = TableA.dID
WHERE DATE(TableC.date) = DATE('now()')</code>
ログイン後にコピー

この改良されたクエリは、共有 ID 列を使用して 4 つのテーブルすべてを接続します。 適切な書式設定とインデントによって読みやすさが向上していることに注目してください。

以上が共有 ID を使用して 4 つの SQL テーブルを効率的に結合するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート