この記事では、SQLにおけるCTE(Common Table Expressions)の使用方法について深掘りします。基本的な使い方から応用例、パフォーマンスへの影響まで、具体的なコード例とその解説を交えてご紹介します。
目次
CTEとは何か
CTE(Common Table Expressions)は、SQLのSELECT、INSERT、UPDATE、DELETE、CREATE VIEW文などにおいて、一時的な結果セットを生成するための高度なクエリの一部です。CTEはサブクエリを簡潔で読みやすい形にし、再帰クエリや複数の操作を連結するのに便利です。
基本的な構文
CTEを使用する基本的なSQLの構文は以下の通りです。
WITH cte_name (column_name1, column_name2, ...)
AS (
SQL_query
)
SELECT * FROM cte_name;
基本的な使用例
CTEを使った基本的なクエリの例を見てみましょう。
単純なSELECTクエリ
以下の例は、employeesテーブルから特定の条件に一致するレコードを取得するものです。
ID | Name | Salary |
---|---|---|
1 | John | 50000 |
2 | Jane | 60000 |
3 | Susan | 55000 |
WITH Employee_CTE (ID, Name, Salary)
AS (
SELECT ID, Name, Salary FROM employees WHERE Salary > 55000
)
SELECT * FROM Employee_CTE;
応用例
CTEの高度な使用例を以下に示します。
階層データのクエリ
CTEは再帰的なクエリをサポートしています。以下は、階層データを表す一例です。
ID | Name | Manager_ID |
---|---|---|
1 | CEO | NULL |
2 | CTO | 1 |
3 | Engineer | 2 |
WITH Recursive_CTE (ID, Name, Manager_ID, Level)
AS (
SELECT ID, Name, Manager_ID, 0 FROM organization WHERE Manager_ID IS NULL
UNION ALL
SELECT o.ID, o.Name, o.Manager_ID, Level + 1
FROM organization o
INNER JOIN Recursive_CTE r ON o.Manager_ID = r.ID
)
SELECT * FROM Recursive_CTE;
複数CTEの連結
一つのクエリ内で複数のCTEを使用することもできます。
WITH CTE1 AS (
SELECT ID, Name FROM table1
),
CTE2 AS (
SELECT ID, Amount FROM table2
)
SELECT CTE1.Name, CTE2.Amount
FROM CTE1
JOIN CTE2 ON CTE1.ID = CTE2.ID;
パフォーマンスへの影響
CTEは一時テーブルにデータを保存しないため、通常は高速です。しかし、大量のデータを扱ったり、複雑な再帰クエリを使用する場合は、パフォーマンスに影響が出る可能性があります。実行計画を確認して、必要に応じて最適化することが重要です。
まとめ
CTEはSQLの高度な機能の一つで、クエリをより簡潔かつ効率的に書くために非常に便利です。基本的な使用方法から応用例、そしてパフォーマンスへの影響についても触れました。この知識を使って、より効率的なデータ処理を行いましょう。
created by Rinker
¥4,554
(2025/01/18 14:22:31時点 Amazon調べ-詳細)
コメント