サイトアイコン ITC Media

【実例付】MySQLでデータを結合|JOINの使い方

(最終更新月:2023年10月)

✔このような方へ向けて書かれた記事となります

「MySQL JOINって何ができるのだろうか?」

「MySQL JOINの使い方が知りたい」

「MySQL JOINを使った実際のケースが見たい」

✔当記事を通じてお伝えすること

当記事では、MySQL JOINの基本的な使い方から、さまざまな種類のJOIN(INNER JOIN, LEFT JOIN, RIGHT JOINなど)の活用方法まで、具体的な例を交えてわかりやすく解説しています。

ぜひ最後までご覧ください。

筆者プロフィール

【現職】プロダクトマネージャー

【副業】ブログ(月間20万PV)/YouTube/Web・アプリ制作

「プログラミング × ライティング × 営業」の経験を活かし、30後半からのIT系職へシフト。現在はプロダクトマネージャーとして、さまざまな関係者の間に入り奮闘してます。当サイトでは、実際に手を動かせるWebアプリの開発を通じて、プログラミングはもちろん、IT職に必要な情報を提供していきます。

【当ブログで紹介しているサイト】

当サイトチュートリアルで作成したデモ版日報アプリ

Django × Reactで開発したツール系Webアプリ

✔人に見せても恥ずかしくないコードを書こう

「リーダブルコード」は、わかりやすく良いコードの定義を教えてくれる本です。

  • 見るからにきれいなコードの書き方
  • コードの分割方法
  • 変数や関数の命名規則

エンジニアのスタンダートとすべき基準を一から解説しています。

何回も読むのに値する本なので、ぜひ手にとって読んでみてください。

MySQL入門とデータベースの作り方

こちらでは、MySQLの基本について見ていきましょう。

MySQLを学ぶことで、データベース管理の基本的なスキルを習得できます。

MySQLとその必要性

MySQLは、世界で最も広く使われているオープンソースのリレーショナルデータベース管理システムのひとつです。

企業や個人サイトでのデータ管理において中心的な役割を果たしています。

使用が無料で、高性能かつ信頼性が高いことが、多くのシステムで利用されている理由です。

データベースとテーブルの基本的な作成手順

データベースの作成は以下のコマンドを使います。

CREATE DATABASE データベース名;

テーブルを作成するには、こちらのコマンド。

CREATE TABLE テーブル名 (カラム名 データ型,...);

これらのコマンドを適切に組み合わせることで、必要なデータ構造を効果的に設計できます。

JOINの基本知識と内部結合のための事前準備

こちらでは、JOINについての基本的な知識と、内部結合をおこなうための準備について説明します。

JOINの基本と役割

JOINは、複数のテーブルから関連するデータを一度に取得するためのSQL文です。

以下は、顧客情報が保存されているテーブルと注文履歴が保存されているテーブルを結合し、特定の顧客の注文履歴を一覧表示する例です。

SELECT customers.customer_name, orders.product_name, orders.order_date
FROM customers
JOIN orders ON customers.customer_id = orders.customer_id
WHERE customers.customer_name = '特定の顧客名';

JOINを使ってcustomersテーブルとordersテーブルをcustomer_idで結合。

その上で、WHERE句を利用して特定の顧客名を条件として指定し、その顧客の注文履歴(商品名と注文日)を一覧表示しています。

JOINを試すための初めてのテーブル作成

まず、結合を試すためには少なくとも2つのテーブルが必要です。

例として、usersテーブルとordersテーブルを作成してみましょう。

usersテーブルはid, nameの2つのカラムから成り立ちます。

CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL
);

ordersテーブルには、id, user_id, product_nameの3つのカラムを用意しましょう。

CREATE TABLE orders (
    id INT PRIMARY KEY AUTO_INCREMENT,
    user_id INT,
    product_name VARCHAR(255) NOT NULL,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

こうして関連するデータをもつ2つのテーブルができれば、JOIN操作を試す準備が整いました。

内部結合の理解と適用

こちらでは、内部結合のメカニズムとその具体的な利用方法を解説します。

内部結合の原理とその使い方

内部結合は、2テーブル間の指定されたカラムの値が一致する行だけを結果として返します

例えば、usersテーブルとordersテーブルを結合する場合、以下のようなSQL文を使用します。

SELECT users.name, orders.product_name FROM users JOIN orders ON users.id = orders.user_id;

ユーザー名とそのユーザーが注文した商品名を一覧表示します。

テーブル名のエイリアスの活用方法

同じテーブルを複数回JOINする場合など、テーブル名のエイリアスが使えます。

SQL文が、読みやすくなるからです。

以下のように活用できます。

SELECT u.name, o.product_name FROM users AS u JOIN orders AS o ON u.id = o.user_id;

USING句の利用とその効果

USING句は、JOINする2テーブルの同名カラムに基づいて結合をおこな場合に利用します。

SELECT name, product_name FROM users JOIN orders USING(id);

ただし、実際にはuser_idのような外部キーカラムを使用することが多いので、上記の例はあくまで理解を助けるためのものです。

同時に多くのテーブルをJOINする方法

複数のテーブルを一度にJOINする場合、順番に結合していきます。

以下は、users, orders, productsの3つのテーブルを結合する例です。

SELECT u.name, o.order_date, p.product_name 
FROM users 
AS u JOIN orders AS o ON u.id = o.user_id JOIN products AS p ON o.product_id = p.id;

外部結合の深掘りとその活用

外部結合を使うと、一致しないデータも結果として取得できます。

内部結合と外部結合の比較

内部結合はマッチしたレコードのみを返しますが、外部結合はマッチしないレコードも含む結果を返します

具体的には以下のようなSQLで確認可能です。

-- 内部結合
SELECT users.name, orders.product_name
FROM users
JOIN orders ON users.id = orders.user_id;

-- 左外部結合
SELECT users.name, orders.product_name
FROM users
LEFT JOIN orders ON users.id = orders.user_id;

左外部結合の作成とその結果

左外部結合は、左テーブルのすべてのレコードと、右テーブルのマッチするレコードを返します。

マッチしない場合、右テーブルのフィールドはNULLです。

SELECT users.name, orders.product_name
FROM users
LEFT JOIN orders ON users.id = orders.user_id;

右外部結合の利用と結果

右外部結合の働きは左外部結合の逆で、右テーブルの全レコードと、左テーブルのマッチするレコードを返します。

SELECT users.name, orders.product_name
FROM users
RIGHT JOIN orders ON users.id = orders.user_id;

外部結合の種類間の互換性について

MySQLでは右外部結合を直接サポートしていませんが、左外部結合を活用して同等の結果を得られます。

要点は、JOINの順番を逆にすることです。

データ取得法と特別な結合場合の処理

こちらでは、データの取得方法や、結合する際の特別なケースにどのように対応するかについて詳しく解説します。

データの取得とカラム指定方法

データを取得する際、必要なカラムだけを指定することで、読み込むデータ量を制限し、処理速度を向上させられます。

SELECT users.id, users.name, orders.product_name
FROM users
JOIN orders ON users.id = orders.user_id;

usersテーブルからidnameordersテーブルからproduct_nameのみを取得しています。

USING句の活用:結合カラム名が同一の場合

結合するカラム名が両テーブルで同じ場合、USING句を使用してシンプルに記述できます。

SELECT users.name, orders.product_name
FROM users
JOIN orders USING(user_id);

この方法を使用すると、ON句よりも簡潔に結合条件を記述できます。

JOIN操作の問題解決と効率化

こちらでは、JOIN操作時に遭遇する可能性がある問題と、JOINをより効果的に利用するためのヒントやテクニックを紹介します。

JOIN操作で遭遇する問題とその対策

JOIN操作中に発生する可能性のある問題には、重複データの発生や性能の低下などがあります。

これらの問題には、適切なインデックスの設定やDISTINCT句の使用で対策が必要です。

JOINの使用でテーブル結合を効果的にするヒントとテクニック

効率的なテーブル結合のためには、以下のようなテクニックが有効です。

まとめ

当記事では、MySQLのJOIN操作について学習してきました。

当記事で学んだ主なポイントは、JOINの基本的な仕組みや使い方、結合時の留意点や効率的なテクニックなどです。

適切に活用することでデータベースからの情報取得が効率的におこなえます。

モバイルバージョンを終了