BackEnd

MySQLでFULL OUTER JOIN (完全外部結合)を行う

投稿日:

はじめに

テーブル結合と言えば、INNER JOIN か LEFT OUTER JOIN 位しか使用した事が無かったのですが、先日、FULL OUTER JOINを使いたいタイミングがありました。

滅多に使わないと思うので備忘録として使い方を残しておきたいと思います。

FULL OUTER JOIN とは

結合する2つのテーブル全ての列(レコード)を抽出する結合方法です。結合条件に当てはまるデータは1つの列にまとめられ、結合条件に当てはまらない場合は片方のテーブルの値はNullになります。
別の言い方をすると、LEFT OUTER JOINの結果とRIGHT OUTER JOINの結果を合わせた(重複は除く)ものと同じ結果が得られます。

具体例で見てみます。サッカー選手と所属チームのテーブルを用意します。

RDMBSはPostgreSQLを使用しています。

選手テーブル

 

選手ID 選手名 チームID
1 中田英寿 1
2 中村俊介 2
3 香川真司 3
4 久保建英 10

 

チームテーブル

チームID チーム名
1 ローマ
2 セルティック
3 マンチェスター
4 ミラン

 

この2つのテーブルをFULL OUTER JOINしてみます。
SELECT soccer_players.name, soccer_players.team_id, soccer_teams.name FROM soccer_players FULL OUTER JOIN soccer_teams ON soccer_players.team_id = soccer_teams.id

結合条件と合致しない列(久保建英とミラン)も両テーブルからNULLを含めて取得されています。

結果

選手名 チームID チーム名
中田英寿 1 ローマ
中村俊介 2 セルティック
香川真司 3 マンチェスター
久保建英 10 NULL
NULL NULL ミラン

MySQLでは

MySQLでは FULL OUTER JOIN 構文が使えないので、LEFT OUTER JOIN と RIGHT OUTER JOIN と UNION を組み合わせて対応します。
LEFT OUTER JOIN の結果と RIGHT OUTER JOIN の結果をUNIONで結合させてます。

CROSS JOIN

おまけにCROSS JOINも使った事が無かったので試してみました。
これは2つのテーブルの列の全ての組み合わせ結果を取得する事が出来ます。

上記の例で言うと、以下の結果が得られます。

選手名 チームID チーム名
中村俊介 2 ローマ
中村俊介 2 セルティック
中村俊介 2 マンチェスター
中村俊介 2 ミラン
中田英寿 1 ローマ
中田英寿 1 セルティック
中田英寿 1 マンチェスター
中田英寿 1 ミラン
久保建英 10 ローマ
久保建英 10 セルティック
久保建英 10 マンチェスター
久保建英 10 ミラン
香川真司 3 ローマ
香川真司 3 セルティック
香川真司 3 マンチェスター
香川真司 3 ミラン

さいごに

FULL OUTER JOIN と CROSS JOIN を試してみました。

使う機会は少ないと思いますが、どなたかの参考になれば。

おすすめ書籍

MySQL徹底入門 第4版 MySQL 8.0対応 SQLアンチパターン

blog-page_footer_336




blog-page_footer_336




-BackEnd
-

執筆者:

免責事項

このブログは、記事上部に記載のある投稿日時点の一般的な情報を提供するものであり、投資等の勧誘・法的・税務上の助言を提供するものではありません。仮想通貨の投資・損益計算は複雑であり、個々の取引状況や法律の変更によって異なる可能性があります。ブログに記載された情報は参考程度のものであり、特定の状況に基づいた行動の決定には専門家の助言を求めることをお勧めします。当ブログの情報に基づいた行動に関連して生じた損失やリスクについて、筆者は責任を負いかねます。最新の法律や税務情報を確認し、必要に応じて専門家に相談することをお勧めします。


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

laravel logo

LaravelでHTTP通信

1 はじめに2 インストール3 基本的な使い方3.1 GETでリクエストを投げる3.2 リクエストヘッダーを指定3.3 クエリパラメータを指定3.4 timeout時間を指定3.5 POSTでリクエス ...

[Dialogflow + CF] アクア様が罵倒してくれたり天気を教えてくれるSlackボットを作る

1 はじめに2 Dialogflowの準備2.1 プロジェクトを作る2.2 Intentを作る2.3 試してみる2.4 WELCOME Intentを作る3 Slackボットを作る4 名前を答える5 ...

Stripe Connectを使って複合プランの継続課金を実装

1 はじめに1.1 想定する継続課金1.2 想定するシチュエーション2 継続課金商品の作成2.1 プランの継続課金商品の作成2.2 ID数の継続課金商品の作成3 実装3.1 プランAとID数を30契約 ...

Go言語

[Go初心者]テストについて学習

1 はじめに2 テスト2.1 エラーの値を比較する2.2 エラーの型を比較する3 httptest3.1 httptestの使い方4 さいごに5 おすすめ書籍 はじめに 今回はGo言語のテストについて ...

Go言語

Go言語の基礎〜Go 1.11 開発環境構築とパッケージバージョン管理〜

1 はじめに2 Go言語(Golang)とは2.1 シンプルな構文2.2 コンパイル言語2.3 並行処理2.4 その他の特徴3 Go開発環境の構築3.1 Goのインストール3.1.1 1. homeb ...

フォロー

blog-page_side_responsive

2023年5月
 123456
78910111213
14151617181920
21222324252627
28293031  

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。