ホームページ >データベース >mysql チュートリアル >LEFT JOIN を使用して 3 つの MySQL テーブルから人物データと恐怖データを取得するにはどうすればよいですか?

LEFT JOIN を使用して 3 つの MySQL テーブルから人物データと恐怖データを取得するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-24 19:53:10419ブラウズ

How Can I Use LEFT JOINs to Retrieve Person and Fear Data from Three MySQL Tables?

恐怖症の人用の 3 つのテーブルを MySQL LEFT JOIN

個人とそれに関連する恐怖のリストを取得するには、相互接続された 3 つのテーブルをシームレスにマージする必要があります。テーブル:

  • 人物: 人物 ID名前SS (社会保障
  • Fears: さまざまな恐怖をリストし、それぞれに固有の FearID が割り当てられます。
  • person_Fear: ID で個人と恐怖の間の橋渡しをします。 PersonID、および FearID

LEFT JOIN クエリの変更

LEFT を作成する最初の試みJOIN で問題が発生しました。指定された結合条件

person_fear.personid = person_fear.fearid は、テーブル間の目的の関係と一致しません。 Person_Fear 仲介を介して Persons テーブルを Fears テーブルに正しくリンクするには、次の変更コードを使用します:

SELECT Persons.Name, Persons.SS, Fears.Fear
FROM Persons
LEFT JOIN Person_Fear
    INNER JOIN Fears
    ON Person_Fear.FearID = Fears.FearID
ON Person_Fear.PersonID = Persons.PersonID

変更内容の説明クエリ

  • LEFT JOIN は、Persons テーブルを Person_Fear テーブルとマージします。ここで、各個人の PersonID は対応するものと一致しますPerson_FearpersonID。これにより、恐怖が関連付けられていない場合でも、すべての人が結果に含まれることが保証されます。
  • INNER JOIN は、person_Fear テーブルを Fears にリンクします。 FearID 列に基づく テーブル。この操作では、Person_Fear テーブルを介して個人に明示的に関連付けられている恐怖のみを取得します。
  • ON 句により、PersonIDPersons テーブルは、 Person_Fear テーブル。これは、Fears テーブルの FearID と一致します。
  • 代替クエリ構文

LEFT JOIN クエリを記述する別の方法は:

この構文は、2 つの LEFT JOIN を使用してテーブルを接続し、必要なデータを取得する場合にも同様に効果的です。

以上がLEFT JOIN を使用して 3 つの MySQL テーブルから人物データと恐怖データを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。