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基礎 弱点克服スクール | 第4回

単一行関数の使用による出力のカスタマイズ ~ 変換関数と条件式の使用方法


  • Facebook
  • X
  • Pocket
  • note
  • hatena

条件式

では、最後にCASE式とDECODEに関する問題です。

問4

次の2つのSQLを確認してください。

(1) SELECT ename, CASE WHEN sal >= (SELECT MAX(sal) FROM emp) THEN 'High' ELSE 'Low' END SAL_MARK FROM emp WHERE deptno = 10;

(2) SELECT ename, DECODE(sal,(SELECT MAX(sal) FROM emp), 'High','Low') FROM emp WHERE deptno = 10;

正しいものを1つ選びなさい。

  • a. 2つともエラーになる
  • b. (1)だけエラーになる
  • c. (2)だけエラーになる
  • d. 2つとも結果を戻す

関数からの出題というより、まるで副問合せからの出題のようです。要するに「12c SQL試験には高度なSQLも出題されますよ」ってことです。関数がいろんなカテゴリに登場するように、副問合せもいろんなカテゴリに登場するような気がします。

単一列単一行副問合せは、実行結果として1つの値しか戻さないので「値」の代わりになります。つまり、「値」を記述できるところなら、単一列単一行副問合せを使用できるんだと覚えておけばよいでしょう。副問合せは、別な機会に改めて解説しますね。

設問の(1)はCASE式です。THENの後には、式または値を指定します。

図6:CASE式
図6:CASE式

CASE式には、CASEの直後に列名を指定し、WHENの直後に条件値だけを記述する「単純CASE式」と、CASEの直後に列名は記述せずに、WHENの直後に列名 比較演算子 条件値を記述する「検索CASE式」があります。WHENに続く比較条件は非等価条件(=以外の演算子)でも構いません。

設問の(2)のDECODEは、複数の条件値と等価条件で比較し、結果を戻します。図6のCASE式と同じ使い方だと思えばいいです。

設問の(1)と(2)は次の実行結果のとおり、2つとも結果を返します(正解は選択肢d)。

SQL> --設問(1)
SQL> SELECT ename,
  2    CASE WHEN sal >= (SELECT MAX(sal) FROM emp)
  3    THEN 'High'
  4    ELSE 'Low'
  5    END SAL_MARK
  6  FROM emp
  7  WHERE deptno = 10;

ENAME      SAL_
---------- ----
CLARK      Low
KING       High
MILLER     Low

SQL> --設問(2)
SQL> SELECT ename,
  2    DECODE(sal,(SELECT MAX(sal) FROM emp),
  3    'High','Low')
  4  FROM emp
  5  WHERE deptno = 10;

ENAME      DECO
---------- ----
CLARK      Low
KING       High
MILLER     Low

いかがでしたか? 12c SQL試験が難しいと言われる一端を見た気がしませんか。「SQLなんて、簡単だろう」と、とりあってくれない先輩に、今回の設問を一緒に解いてもらってみてはいかがでしょう。きっと、合格した暁には、おごってくれないまでも称賛してもらえるのではないでしょうか。

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

  • 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/105 2016/09/12 19:11

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

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

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

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

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

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

メールバックナンバー

アクセスランキング

アクセスランキング