ここから本文です

SQL ServerのSQL文について質問です 下記のような列A、B、C、d、e、f、gがある...

rpd********さん

2017/10/2700:10:04

SQL ServerのSQL文について質問です

下記のような列A、B、C、d、e、f、gがあるテーブルで、

列A、B、Cまたは列d、e、f、gのどこかに数値が入っているかつその数値がどこか1つでも4以上ならばOKというCASE文を用いたSQLを書きたいです。
列A~gが全てNULLの場合はOKとなります。
このテーブルは全て数値型で、空欄部分はNULLとなっております。

|A|B|C|d|e|f|g|
--------------
| | |4| | | | | OK
| | | | | | |4| OK
| |4|2| | | | | OK
| | | | | |5|1| OK
| | |6| | | |6| OK
| |1|0| | | |7| OK
|3|3|0| | | | | NG
| | | |3|2|1|0| NG
| | |1| | |2|1| NG
| | | | | | | | OK

よろしくお願いします。

閲覧数:
34
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

pie********さん

2017/10/2709:18:08

SELECT
A
,B
,C
,d
,e
,f
,g
,CASE WHEN (A IS NULL AND B IS NULL AND C IS NULL AND d IS NULL AND e IS NULL AND f IS NULL AND g IS NULL)
OR (A >= 4 OR B >= 4 OR C >= 4 OR d >= 4 OR e >= 4 OR f >= 4 OR g >= 4)
THEN 'OK' ELSE 'NG' END AS RESULT
FROM TEST

ごり押しですが

質問した人からのコメント

2017/10/27 09:38:45

できました。
ありがとうございました。

この質問につけられたタグ

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる