ネストされたクエリ
メニューを表示するにはスワイプしてください
学校の管理者はあなたの最近の成果に満足しており、今後の進展を期待しています。
彼らが夏休みに入る中、あなたには新しい手法の探求やSQLスキルの向上の機会があります。
今回の注目点は、SQLの重要な概念であるネストされたクエリです。
ネストされたクエリ、またはネストされたサブクエリは、SQLにおいてクエリの中に別のクエリが含まれる構造。これらの構造は、データのフィルタリング、計算、取得など多様な操作を可能にし、しばしばサブクエリの統合が必要となる。
会社のデータベースからの例を見てみましょう。会社の成長に伴い、新しい department テーブルが追加されました。これにより、データベースの仕組みが変化します。
新しいテーブルの構造を確認し、その役割を把握しましょう。
新しいテーブルには部門、その種類、および予算が含まれています。また、employeeテーブルには、各従業員が所属する部門情報が記録されています。
ネストされたクエリを使用して、予算が500,000ドル以下の部門で働く従業員を取得する例を考えます。
1234567SELECT * FROM employees WHERE department IN ( SELECT name FROM department WHERE budget <= 500000 )
WHERE句は、部門名が内側のクエリで取得されたテーブルに存在することを指定するために使用。
このクエリを2つのクエリに分解して、その動作を確認。まず、予算が500,000ドル以下の部門名を取得(内側のクエリ):
123SELECT name FROM department WHERE budget <= 500000
取得した結果を考慮し、これらの部門の従業員に関する情報を取得するための2つ目のクエリを作成:
12345SELECT * FROM employees WHERE department IN ( 'Marketing', 'Human Resources', 'Finance', 'Customer Service', 'Legal' )
このクエリの結果は、最初のクエリと同じになります。
以下はステップごとの説明です:
-
内側のクエリが必要な部門の
namesを取得; -
WHERE句が、これらの部門が内側のクエリのテーブルに存在するかを確認; -
必要な結果が得られる。
内側のクエリの基本的な構文は以下の通りです:
SELECT columns
FROM table_1
WHERE column_name IN (
SELECT column
FROM table_2
other clauses
)
ネストされたクエリを使用する際は、次の重要なポイントに注意してください:
-
サブクエリの単一結果:ネストされたクエリは1列のみを返すようにします。比較で使用する場合、理想的には単一の値を返す必要があります。これは
=,>,<,>=,<=,<>などの演算子で重要です; -
データ型:返される列のデータ型が比較対象の列と一致している必要があります。これによりエラーを防げます;
-
最適化:ネストされたクエリは、メインクエリの各行ごとに実行される場合、処理が遅くなることがあります;
-
IN演算子の使用:ネストされたクエリでは、部分集合内の値を確認するために
IN演算子がよく使われます。より複雑な条件には比較演算子も利用できます。
1. SQLにおけるネストされたクエリとは何ですか?
2. ネストされたクエリでサブセット内の値を確認するためによく使われるSQL演算子はどれですか?
3. ネストされたクエリが返すカラムのデータ型が比較対象のカラムと一致することが重要なのはなぜですか?
フィードバックありがとうございます!
AIに質問する
AIに質問する
何でも質問するか、提案された質問の1つを試してチャットを始めてください