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

データ定義言語(DDL)の概要

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena

データ型(続き)

LONGの次はINTERVALに関する出題です。

問2

次の問合せを確認してください。

SELECT INTERVAL '600' YEAR TO MONTH FROM dual;  

この問合せを実行すると、どのように出力されますか。最も適切なものを選択しなさい。

  • a. +50
  • b. +600
  • c. +00-50
  • d. +60-00
  • e. エラーになる

さっそく実行してみましょう。

SQL> SELECT INTERVAL '600' YEAR TO MONTH FROM dual;
SELECT INTERVAL '600' YEAR TO MONTH FROM dual
                *
行1でエラーが発生しました。:
ORA-01867: 間隔が無効です。

結果から分かるとおり、正解は選択肢eです(選択肢a、b、c、dは不正解)。 INTERVALというのは期間を扱うデータ型で、YEAR TO MONTHDAY TO SECONDがあります。

構文 INTERVALデータ型の構文
INTERVAL 期間値 YEAR[(精度)] TO MONTH

INTERVAL 期間値 {DAY | HOUR | MINUTE}[(精度)] TO {HOUR | MINUTE | SECOND}[(精度)]

YEARフィールドの精度は桁数で、デフォルトは2です。したがって、600という3桁の年を扱いたいのであれば、次のように桁数を指定しなければいけません。

SQL> SELECT INTERVAL '600' YEAR(3) FROM dual;

INTERVAL'600'YEAR(3)
-----------------------------------
+600-00

また、「600年」という「年」だけであれば、TO MONTHは指定しません。TO MONTHと指定するなら、次のように「600年0か月」と分かるように、期間値に「月」まで明記する必要があります。

SQL> SELECT INTERVAL '600-00' YEAR(3) TO MONTH FROM dual;

INTERVAL'600-00'YEAR(3)TOMONTH
-----------------------------------
+600-00

当然、次の実行例で確認できるとおり、期間値に指定できる「月」は1~11までです。

SQL> SELECT INTERVAL '600-12' YEAR(3) TO MONTH FROM dual;
SELECT INTERVAL '600-12' YEAR(3) TO MONTH FROM dual
                *
行1でエラーが発生しました。:
ORA-01843: 指定した月が無効です。

SQL> SELECT INTERVAL '600-11' YEAR(3) TO MONTH FROM dual;

INTERVAL'600-11'YEAR(3)TOMONTH
---------------------------------------------------------------------------
+600-11

DAY TO SECONDの期間値には、日数、HH[:MI[:SS[.n]]]MI[:SS[.n]]またはSS[.n]の形式で時間を指定します。nは、秒の小数部で指定した精度(デフォルトは6)に四捨五入されるので注意してください。

INTERVALは「賞味期間は3年8か月」なんていうデータも扱えるので、実務でも使えると思いますよ。そもそも、ちょっと出題されただけなのに、INTERVALが「すごく出題された」という印象を与えているのは、INTERVALを使い慣れていない人が多いからだと思います。自分で任意の期間値を指定してSELECTしてみてください。

次のページ
制約

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

  • 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/297 2016/12/15 14:00

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

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

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

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

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

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

メールバックナンバー

アクセスランキング

アクセスランキング