SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

HRzine Day(エイチアールジン・デイ)は、人が活き会社が成長する人事のWebマガジン「HRzine」が主催するイベントです。毎回、人事の重要課題を1つテーマに設定し、識者やエキスパードが持つ知見・経験を、参加者のみなさんと共有しています。

直近開催のイベントはこちら!

HRzine Day 2024 Winter

2024年2月1日(木)12:00~17:40

主要製品スペック一覧

人事業務の効率・確度・精度を高めるために欠かせないHRテクノロジー。その主な製品の機能を分野ごとに比較できる資料群です。製品検討の参考資料としてご活用ください。

人事労務管理システム<br>主要製品スペック一覧 2023

人事労務管理システム
主要製品スペック一覧 2023

その他のスペック一覧

タレントマネジメントシステム<br>主要製品スペック一覧 2023

タレントマネジメントシステム
主要製品スペック一覧 2023

採用管理システム<br>主要製品スペック一覧 2023

採用管理システム
主要製品スペック一覧 2023

落とし穴はこれで回避! Oracle DB 12c SQL基礎 弱点克服スクール | 第8回

副問合せの基本確認と難問の克服


  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena

副問合せが使用できる場所

私が「12cSQL試験は難易度高いなぁ〜」と思ったのは、次のような設問を見かけたときです。さあ、今回最後の問題! 十分に悩んでください。

問3

次の中で実行時にエラーになるSQLはどれですか

  • a. SELECT (SELECT AVG(salary) FROM employees),last_name,salary FROM employees;
  • b. INSERT INTO employees (employee_id,last_name,email,hire_date,job_id)
    VALUES((SELECT MAX(employee_id)+1 FROM employees),'SCOTT','SCOTT',SYSDATE,'SA_REP');
  • c. UPDATE employees SET (salary,manager_id) =
    (SELECT salary,manager_id FROM employees WHERE employee_id = 108)
    WHERE employee_id = 200;
  • d. DELETE FROM employees WHERE salary >=
    (SELECT MAX(salary) FROM employees GROUP BY department_id)

実行結果を確認する前に、この設問において重要なことを先にお話しします。

FROMWHEREでは、複数列、複数行を含むすべての副問合せを記述できる。

UPDATESETにおいては、単一列または複数列で、単一行の副問合せを記述することができます。

そして、単一列、単一行を戻す副問合せは、FROM句、WHERE句だけでなく、次に記述することができます。

  • SELECT
  • INSERTVALUES
  • ORDER BY
表1:副問合せが使用可能な場所
使用可能な句 単一列 複数列 単一行 複数行
FROM
WHERE
UPDATESET ×
SELECT × ×
INSERTVALUES × ×
ORDER BY × ×

単一列とはただ1つの列を副問合せが戻す場合をいい、複数列とは2つ以上のの値を戻す副問合せのことをいいます。

複数列の場合、副問合せから戻される値と比較する列は、必ず括弧()で囲む必要があります。したがって、選択肢a、b、cは正解です。

SQL> -- 選択肢a
SQL> SELECT (SELECT AVG(salary) FROM employees),
  2  last_name,salary FROM employees;
  
(SELECTAVG(SALARY)FROMEMPLOYEES) LAST_NAME           SALARY
-------------------------------- --------------- ----------
                      6461.83178 King                 24000
                      6461.83178 Kochhar              17000
                      
                      (途中省略)
                      
                      6461.83178 Gietz                 8300
                      6461.83178 Allen

108行が選択されました。


SQL> -- 選択肢b
SQL> INSERT INTO employees (employee_id,last_name,email,
  2   hire_date,job_id)
  3   VALUES((SELECT MAX(employee_id)+1 FROM employees),
  4   'SCOTT','SCOTT',SYSDATE,'SA_REP');
  
1行が作成されました。


SQL> -- 選択肢c
QL> UPDATE employees SET (salary,manager_id) =
  2  (SELECT salary,manager_id FROM employees WHERE employee_id = 108)
  3  WHERE employee_id = 200;

1行が更新されました。

選択肢dは副問合せから複数行戻されるのに、主問合せの比較演算子が>=ANY、または>=ALLではなく、1行としか比較できない>=を使用しているため、実行時にエラーになります。

SQL> DELETE FROM employees WHERE salary >=
  2  (SELECT MAX(salary) FROM employees GROUP BY department_id);
(SELECT MAX(salary) FROM employees GROUP BY department_id)
 *
行2でエラーが発生しました。:
ORA-01427: 単一行副問合せにより2つ以上の行が戻されます

いかがでしたか? 副問合せは、単一行のときは=演算子で比較して、複数行のときはIN演算子で比較する。これさえ分かっていれば正解できるよ、というレベルの出題ではないことがお分かりいただけたでしょうか。

結合や副問合せは実務の中でも重要ですので、投げ出さずに頑張ってください。

この記事は参考になりましたか?

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena
めざせオラクルマスターホルダー! Oracle DB 12c SQL基礎 弱点克服スクール連載記事一覧

もっと読む

この記事の著者

林 優子(ハヤシ ユウコ)

日本オラクル株式会社の教育ビジネスのスタートアップを全面的に支援し、バージョン5の頃からOracleに携わるベテラン講師として知る人も多い。Oracle認定講師を表彰するExcellent Instructorを連続受賞。1ランク上のITスペシャリスト育成を目標に、データベース分野にとどまらず「プレゼンテーション」、「ロジカルシンキング」などのトレーニングも手がけている。著書に『オラクルマスター教科書』シリーズ(翔泳社)、『プロとしてのデータモデリング入門』(SBクリエイティブ)など。その他、雑誌執筆、著書・メディア出演も多数。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事をシェア

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena
HRzine
https://hrzine.jp/article/detail/214 2016/12/08 14:11

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

HRzine Day(エイチアールジン・デイ)は、人が活き会社が成長する人事のWebマガジン「HRzine」が主催するイベントです。毎回、人事の重要課題を1つテーマに設定し、識者やエキスパードが持つ知見・経験を、参加者のみなさんと共有しています。

2024年2月1日(木)12:00~17:40

イベントカレンダーを見る

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング