SHOEISHA iD

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

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

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

HRzine×SmartHR 人材・組織活性化フォーラム

2024年12月6日(金)13:00~15:30

主要製品スペック一覧

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

eラーニング・LMS<br>主要製品スペック一覧 2024

eラーニング・LMS
主要製品スペック一覧 2024

その他のスペック一覧

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

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

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

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

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

12c SQL基礎の総復習「模擬問題」

  • Facebook
  • X
  • Pocket
  • note
  • hatena

 ここまで11回にわたり、12c SQL基礎の全範囲を解説してきました。今回が最終回とするなら、やっぱり実力診断?! ですよね。全問正解して、受験に自信を付けてくださいね。

  • Facebook
  • X
  • Pocket
  • note
  • hatena

本稿の模擬試験は全部で10問です。なお、本講座は基礎から全部解説したわけではなく、「この講座で取り上げたことをきっかけにして自分で学習してくださいね」という意図を含んでいました。そのため、中には本講座で取り上げなかった内容も含まれています。設問ごとに解説をしますので、総復習&実力診断のつもりで挑戦してください!

リレーショナルデータベースの概要

問1

RDBの特徴として正しいものを2つ選択しなさい。

  • a. E.F.Coddのルールをサポートする
  • b. 継承の機能をサポートする
  • c. データはカプセル化される
  • d. 結合を使ってデータを取得する

Oracleのバージョンを問わず出題される、一般的な知識を問う問題です。選択肢の文章は短めで、どうにでも解釈できるような表現が使われている場合があります。消去法であいまいな選択肢を正解数まで取り除いていくとよいでしょう。

不正解の選択肢には、オブジェクト指向データベースの特徴(選択肢bとc)が用いられることが多いようです。細かい解説は省きますが(気になる方は「リレーショナルデータベース」「オブジェクト指向データベース」というキーワードでWeb検索してみてください)、本問の正解は選択肢aとdです。

SELECT文によるデータの取得

問2

次の中で実行できるSQL文を選択しなさい。

  • a. SELECT last_name,salary,salary + (salary * 0.1) “Provisional”
    FROM employees
    WHERE Provisional > 1000;
  • b. SELECT last_name,salary,salary + (salary * 0.1) “Provisional”
    FROM employees “EMP”;
  • c. SELECT department_id,avg(salary + (salary * 0.1)) “Provisional”
    FROM employees
    HAVING “Provisional” > 1000
    GROUP BY department_id;
  • d. SELECT last_name,salary,salary + (salary * 0.1) “Provisional”
    FROM employees
    ORDER BY “Provisional”;

本講座では、SQLの基礎の基礎は取り上げませんでしたが、SELECT句におけるDISTINCTの使い方や別名の使い方といった出題もあります。例えば、別名。シングルクォーテーションは文字列データや日付データを囲むときに使用する記号なので、別名を使用するときにはダブルクォーテーションを使用します。それも、「大文字/小文字を区別したい」「命名規則に反する文字(記号や空白)を使用したい」という場合には必ず。そのような特別な事情がなければ、ダブルクォーテーションで囲む必要はありません。そのあたりは、大丈夫でしょう。

ところで、FROM句で表別名を使用する場合も、ダブルクォーテーションで囲むんでしたっけ? はい、囲んでも囲まなくてもどちらでも構いません。ですので、選択肢bは正解です(以下は選択肢bでの実行例)。

SQL> SELECT last_name,salary,salary + (salary * 0.1) "Provisional"
  2  FROM   employees "EMP";

LAST_NAME                          SALARY Provisional
------------------------------ ---------- -----------
King                                24000       26400
Kochhar                             17000       18700
(途中省略)
Higgins                             12008     13208.8
Gietz                                8300        9130

107行が選択されました。

ただ実際には、ダブルクォーテーションで囲まなければいけないような特殊な文字や記号を使って、表別名を付けるケースはまずないでしょう。なお、表別名を指定するのに、ASキーワードは使用できないことを忘れないでください。

では、WHERE句で別名を使用するときはどうでしたか? 次の実行結果から分かるように、ダブルクォーテーションの有無にかかわらず、WHERE句では別名は使用できません。ですので、選択肢aは不正解です(以下は選択肢aでの実行例)。

SQL> SELECT last_name,salary,salary + (salary * 0.1) "Provisional"
  2  FROM   employees
  3  WHERE  Provisional > 1000;
WHERE  Provisional > 1000
       *
行3でエラーが発生しました。:
ORA-00904: "PROVISIONAL": 無効な識別子です。

SQL> SELECT last_name,salary,salary + (salary * 0.1) "Provisional"
  2  FROM   employees
  3  WHERE  "Provisional" > 1000;
WHERE  "Provisional" > 1000
       *
行3でエラーが発生しました。:
ORA-00904: "Provisional": 無効な識別子です。

ということは、HAVING句、GROUP BY句、ORDER BY句で使用することもできないんでしたっけ? 次の実行結果のとおり、HAVING句とGROUP BY句はWHERE句と同様、ダブルクォーテーションの有無にかかわらず使用できません。ですので、選択肢cは不正解です(以下は選択肢cでの実行例)。

SQL> SELECT department_id,avg(salary + (salary * 0.1)) "Provisional"
  2  FROM   employees
  3  HAVING  "Provisional" > 1000
  4  GROUP BY department_id;
HAVING  "Provisional" > 1000
        *
行3でエラーが発生しました。:
ORA-00904: "Provisional": 無効な識別子です。

しかし、ORDER BY句は使用できます。したがって、選択肢dは正解です(以下は選択肢dでの実行例)。

SQL> SELECT last_name,salary,salary + (salary * 0.1) "Provisional"
  2  FROM   employees
  3  ORDER BY  "Provisional";

LAST_NAME                          SALARY Provisional
------------------------------ ---------- -----------
Olson                                2100        2310
Philtanker                           2200        2420
(途中省略)
Kochhar                             17000       18700
King                                24000       26400

107行が選択されました。

ORDER BY句では別名を使用することができます。ただし、次の実行例が示すとおり、ダブルクォーテーションを付けて定義した別名はダブルクォーテーションを付けて使用しなければいけません。

SQL> SELECT last_name,salary,salary + (salary * 0.1) "Provisional"
  2  FROM   employees
  3  ORDER BY  Provisional;
ORDER BY  Provisional
          *
行3でエラーが発生しました。:
ORA-00904: "PROVISIONAL": 無効な識別子です。

次のページ
OFFSET ROWS、FETCH NEXT ROWS、WITH TIES

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

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

もっと読む

この記事の著者

林 優子(ハヤシ ユウコ)

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

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

この記事をシェア

  • Facebook
  • X
  • Pocket
  • note
  • hatena
HRzine
https://hrzine.jp/article/detail/412 2017/02/22 14:00

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

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

2024年12月6日(金)13:00~15:30

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

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

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

メールバックナンバー

アクセスランキング

アクセスランキング