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

単一行関数の使用による出力のカスタマイズ: 文字列関数・日付関数・数値関数の問題を制覇する


  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena

日付関数の問題

問3

emp表には、入社日を扱うhiredate列(DATE型)があります。正常に実行されるのはどのSQL文ですか。

  • a. SELECT hiredate + 1/24 FROM emp;
  • b. SELECT hiredate + 7 FROM emp;
  • c. SELECT ADD_MONTHS(hiredate,-7) FROM emp;
  • d. SELECT MONTHS_BETWEEN(hiredate,7) FROM emp;
  • e. SELECT NEXT_DAY(hiredate,7) FROM emp;

Oracleの日付型は、年月日だけでなく時刻(時分秒)も扱います。日付の加算(+)、減算(-)の単位は「日」です。したがって、選択肢aの+1/24は1時間後、選択肢bの+7は7日後の日付を返します。

ADD_MONTHS関数は、第1引数の日付に第2引数で指定された月数を加算した日付を返します。第2引数が正数なら加算され、負数なら減算されます。つまり、選択肢cは7か月前の日付が返されます。

MONTHS_BETWEEN関数は、第1引数と第2引数の差(月数)を戻します。したがって、2つの引数はどちらも日付型でなければならないため、選択肢dはエラーになります。

NEXT_DAY関数の第2引数は曜日で、「対象日付(第1引数)の次の○○曜日(第2引数)はいつ?」を求めます。第2引数は、曜日を表す文字列(土曜日なら'SATURDAY')や、曜日を表す数値を指定できます。曜日を表す数値は、1が日曜日で、7が土曜日です。お間違えなく。

SQL> SELECT SYSDATE, NEXT_DAY(SYSDATE,'SATURDAY'),NEXT_DAY(SYSDATE,7)
  2  FROM dual;

SYSDATE  NEXT_DAY NEXT_DAY
-------- -------- --------
15-12-21 15-12-26 15-12-26

ということで、正解は次のとおり、選択肢abceです。

SQL> -- a
SQL> SELECT hiredate + 1/24 FROM emp
  2  WHERE deptno = 10;

HIREDATE
--------
81-06-09
81-11-17
82-01-23

SQL> -- b
SQL> SELECT hiredate + 7 FROM emp
  2  WHERE deptno = 10;

HIREDATE
--------
81-06-16
81-11-24
82-01-30

SQL> -- c
SQL> SELECT ADD_MONTHS(hiredate,-7) FROM emp
  2  WHERE deptno = 10;

ADD_MONT
--------
80-11-09
81-04-17
81-06-23

SQL> -- d
SQL> SELECT MONTHS_BETWEEN(hiredate,7) FROM emp
  2  WHERE deptno = 10;
SELECT MONTHS_BETWEEN(hiredate,7) FROM emp
                               *
行1でエラーが発生しました。:
ORA-00932: データ型が一致しません: DATEが予想されましたがNUMBERです。

SQL> -- e
SQL> SELECT NEXT_DAY(hiredate,7) FROM emp
  2  WHERE deptno = 10;

NEXT_DAY
--------
81-06-13
81-11-21
82-01-30

言語系の試験は、実行した結果を頭の中で想像しなければいけないので、解いていると疲れますよね。最後はシンプルな問題にしましょう。

数値関数の問題

問4

Oracle Databaseに組み込まれているSQL関数を使用して実行できる算術演算はどれですか?

  • a. 乗算
  • b. 徐算
  • c. べき乗
  • d. 商の余り
  • e. 平方根

正解は、選択肢cdeです。

乗算と徐算はSQL関数ではなく、「*」演算子、「/」演算子で求めます。一方、べき乗はPOWER関数、商の余りはMOD関数、平方根はSQRT関数で求めます。

なお、数値関数と日付関数に関して、今回触れなかったTRUNC関数とROUND関数も大切ですので確認しておきましょう。

次回は、単一行関数のうち「変換関数」を取り上げます。予習しておいてくださいね。

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

  • 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/53 2016/09/12 19:10

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

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

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

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

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

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

メールバックナンバー

アクセスランキング

アクセスランキング