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基礎 弱点克服スクール | 第12回(最終回)

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

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena

変換関数と条件式の使用

問5

PRODUCTS表の構造とデータを確認してください。

NAME                  NULL?    TYPE
--------------------- -------- ------------------
PROD_ID               NOT NULL NUMBER
PRICE                          VARCHAR2(15)

   PROD_ID PRICE
---------- ---------------
         1 $300.25
         2 $20.00
         3 $5,420.75  

あなたは、製品価格に20%の割引を適用し、製品価格と同じ書式で割引後の額を出力する必要があります。必要な結果を得るための最適なSQL文を選択しなさい。

  • a. SELECT prod_id,price*0.8
    FROM products;
  • b. SELECT prod_id, TO_CHAR(price*(1-0.2),'$999,999.90')
    FROM products;
  • c. SELECT prod_id, TO_CHAR(TO_NUMBER(price)*0.8,'$9,999.90')
    FROM products;
  • d. SELECT prod_id, TO_CHAR(TO_NUMBER(price,'$999,999.90')*(1-0.2),'$999,999.90')
    FROM products;

変換関数は第4回でしっかり解説しましたので、日付の書式などは皆さんバッチリでしょう。しかし、データ型については復習が必要だと思い、用意したのがこの設問です。

設問のデータ構造からprice列は文字列型であることがわかります。文字列型に対して加減乗除を行うと、次の実行結果のとおりエラーになります(選択肢a不正解)。

SQL> --選択肢a
SQL> SELECT prod_id,price*0.8
  2  FROM products;
SELECT prod_id,price*0.8
               *
行1でエラーが発生しました。:
ORA-01722: 数値が無効です。

だから、選択肢bのようにTO_CHAR関数の第1引数に当てはめて、書式設定をしようとしたらエラーになります(以下は選択肢bでの実行例)。TO_CHAR関数の第1引数は、日付型か数値型です。

SQL> --選択肢b
SQL> SELECT prod_id,
  2  TO_CHAR(price*(1-0.2),'$999,999.90')
  3  FROM products;
TO_CHAR(price*(1-0.2),'$999,999.90')
        *
行2でエラーが発生しました。:
ORA-01722: 数値が無効です。

文字列型を数値型に変換するときに使うのはTO_NUMBER関数です。対象となる文字列に数値しか含まれていないなら書式の省略は可能ですが、選択肢cのように記号が含まれているならば、書式を指定しないとエラーになります(以下は選択肢cでの実行例)。

SQL> --選択肢c
SQL> SELECT prod_id,
  2  TO_CHAR(TO_NUMBER(price)*0.8,'$9,999.90')
  3  FROM products;
TO_CHAR(TO_NUMBER(price)*0.8,'$9,999.90')
        *
行2でエラーが発生しました。:
ORA-01722: 数値が無効です。

TO_NUMBER関数の第2引数において「先頭に通貨記号があり、3桁ごとにカンマがあり小数点以下は2桁だよ」とOracleに言ってやってはじめて数値に変換され、加減乗除が可能になります。設問では「製品価格と同じ書式で割引後の額を出力する必要」があると言っているので、最後にTO_CHAR関数で書式指定をするのも忘れないでください。これらを満たす選択肢dは正解です(以下は選択肢dでの実行例)。

SQL> --選択肢d
SQL> SELECT prod_id,
  2  TO_CHAR(TO_NUMBER(price,'$999,999.90')*(1-0.2),'$999,999.90')
  3  FROM products;

   PROD_ID TO_CHAR(TO_NUMBER(PRICE,
---------- ------------------------
         1      $240.20
         2       $16.00
         3    $4,336.60

次のページ
グループ関数の使用による集計データのレポート

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

  • 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/412 2017/02/22 14:00

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

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

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

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

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

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

メールバックナンバー

アクセスランキング

アクセスランキング