質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

2回答

2697閲覧

SQL NULLIF関数について

niconicodryyy

総合スコア36

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2019/04/22 01:38

編集2019/04/22 02:15

*質問を編集しました。
オラクル SQLのNULLIF関数についてですが
テキスト(俗に言う白本です)にはNULLIF(式1,式2)とあり
式1にリラテルのNULL値以外を指定する必要があるとありますが
NULL値を指定してもエラーにはならいのでしょうか?

SQL

1SELECT product_id, 2 NVL2(NNULLIF(list_price,min_price),100,0) 3FROM products;

問題文のSQL文をそのまま抜き出してあります。
この問題で実行結果として正しいモノを選びなさいとあり
1:LIST_PRICE列にNULL値が含まれている場合、エラーになる
2:LIST_PRICE列にNULL値が含まれている場合、0が表示される

とあり答えは2なります。
NULLIFの式1にNULL値を指定するとエラーになるはずなのに何故
0が表示されるのでしょうか?

*問題に指定の表、追記等はありませんのでデータ型等でのエラーはないと仮定します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

式1にリラテルのNULL値以外を指定する必要があるとありますが
NULL値を指定してもエラーにはならいのでしょうか?

試す環境も無くて演習しているのですか?
都度、試せばわかる質問をされるつもりですか?

そもそもNULLIFはNULL以外の値との比較関数ですので、第一引数にNULLを指定することになるケースでは使用しません。

第一引数にNULLを指定するとエラーになります。

使い勝手が良いのはCASE式でしょうね。

追記

1:LIST_PRICE列にNULL値が含まれている場合、エラーになる
2:LIST_PRICE列にNULL値が含まれている場合、0が表示される

とあり答えは2なります。
NULLIFの式1にNULL値を指定するとエラーになるはずなのに何故0が表示されるのでしょうか?

NULLIFの式1にNULL値を指定するとエラーになる
これは、NULLIF(Null,min_price)のようにリテラルのNUllを指定した場合で、NULLIF(list_price,min_price)の場合はエラーにはなりません。
NULLIF

NULLIFは、expr1とexpr2を比較します。式が等しい場合、関数はNULLを返します。異なる場合は、expr1を戻します。expr1には、リテラルNULLを指定できません。

list_priceがNullの場合、NULLIF(list_price,min_price)はNUllを返却し、その結果をNVL2の指定で0が返却されます。

※その設問はNULLIFの「expr1には、リテラルNULLを指定できません。」を正しく理解しているかについてですから、リファレンスなどの読み込みが不足しているという事です。

投稿2019/04/22 01:53

編集2019/04/22 03:50
sazi

総合スコア25195

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

質問する前に、実際にSQLを実行しては?
マニュアルもきちんと読んでください。NULLIF

投稿2019/04/22 02:22

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問