この記事では、SQLにおけるIN句を使って複数のテーブルからデータを取得するクエリの例について解説します。IN句は複数の値を一度に検索するための便利な手段ですが、複数テーブルを対象にする場合にはどのように使用するのか、その方法を具体的なSQLクエリを使って説明します。
目次
IN句の基本
IN句は、指定された複数の値のいずれかに一致する行を選択するSQLの構文です。基本的な形は以下の通りです。
SELECT * FROM table1 WHERE column1 IN ('value1', 'value2', 'value3');
単一テーブルでの使用例
id | name | age |
---|---|---|
1 | 田中 | 25 |
2 | 佐藤 | 30 |
3 | 鈴木 | 22 |
上記のテーブル1から、ageが25または30のユーザーを選択するクエリは以下の通りです。
SELECT * FROM テーブル1 WHERE age IN (25, 30);
複数テーブルからのデータ取得
IN句を使って複数のテーブルからデータを取得する場合の基本的な考え方と例を以下に示します。
関連するテーブルの例
order_id | user_id | product_id |
---|---|---|
1 | 1 | 101 |
2 | 2 | 102 |
3 | 1 | 103 |
IN句を使った複数テーブルからのデータ取得
複数のテーブルからデータを取得する場合、主にサブクエリと組み合わせて使用します。以下は、テーブル1(ユーザー情報)とテーブル2(注文情報)から、特定の条件に一致するデータを取得するSQLクエリの例です。
SELECT * FROM テーブル1
WHERE id IN (SELECT user_id FROM テーブル2 WHERE product_id IN (101, 103));
このクエリでは、product_idが101または103の注文をしたユーザーの情報をテーブル1から取得しています。
まとめ
SQLのIN句を使うと、複数の値に一致するデータを効率よく取得できます。複数のテーブルからデータを取得する場合は、サブクエリと組み合わせることで、目的に応じた柔軟なデータ取得が可能です。具体的なクエリを通じて理解を深めると、より高度なデータ操作が容易になります。
created by Rinker
¥4,554
(2025/01/18 14:22:31時点 Amazon調べ-詳細)
コメント