
select max(COL_1) from TBL
where COL2 = 'hoge';
というようなSQLがあり、この条件での選択されるレコードが存在しないとき
max(COL_1)の値を"0"(ゼロ)にしたいのですが。。。
select nvl(max(COL_1),NULL,0) from TBL
where COL2 = 'hoge';
と修正しても結果は変わらず「レコードが選択されませんでした。」
となってしまいます。
他にdecodeや、countも試したのですが、力量不足のため、上手くいきません。。
どなたかご教授願います。
Oracle 9i で SQL*Plus 使用しています。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
dual表から1件0を取得し、集計したらどうでしょう。
select A.COL, sum( nvl( CNT, 0 ) )
from (
select COL_2 COL
, count( COL_1 ) CNT
from TBL
where COL_2 = 'hoge'
group by COL_2
union
select 'hoge' COL
, 0 CNT
from dual
) A
group by A.COL
No.2
- 回答日時:
外部結合にしてはいかがでしょうか。
select decode(count(COL_1),0,0,max(COL_1)) col_1,
COL_2
from TBL
where COL_2(+) = 'hoge'
group by COL_2;
実際に環境がないため断言はできませんが
結果は
col_1 col_2
---------------
0 null
になるはずです。
No.1
- 回答日時:
> select nvl(max(COL_1),NULL,0) from TBL
> where COL2 = 'hoge';
でなく
select nvl(max(COL_1),0) from TBL
where COL2 = 'hoge';
とする。
この回答への補足
回答ありがとうございます。
すこし質問内容が間違っておりました。
正確に申しますと、group byを使用した際の
NO_ROW時の帰り値の差異に関する質問となります。
select decode(count(COL_1),0,0,max(COL_1))
from TBL
where COL_2 = 'hoge';
では、ちゃんと数字が帰ってきます。(レコードが存在しない場合は'0'で。)
ところが、↓だとレコードが無い場合には
レコードが選択されませんでした。 と値を返してくれません。。
どうすればよろしいでしょうか。。
select decode(count(COL_1),0,0,max(COL_1)),COL_2
from TBL
where COL_2 = 'hoge'
group by COL_2;
何卒、ご教授を御願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- PHP PHP MySql ページング 2 2022/09/20 06:38
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- Access(アクセス) アクセス 有効なフィールド名、または式として認識できませんのエラー 3 2022/08/19 11:53
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Excel(エクセル) Excel 、この式はどのように解釈すればいいのでしょうか 4 2023/02/03 08:53
- PostgreSQL PostgreSQL レコードからアイテム種類数を取得したい 2 2022/11/23 22:31
- MySQL SQLです。下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 「昨年の各月の総降 1 2023/07/01 00:32
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
副問合せにLIKE文を使う方法は...
-
オラクル12C_SQLPlusで実行す...
-
続.ORACLEのSELECTのソートに...
-
質問です。 下記のテーブルとデ...
-
データベースのカラムの型がCHA...
-
列1と列2の関係性で列3の条...
-
教えてください。Oracleで作成...
-
' シングルクォート " ダブルク...
-
バッチファイルで複数フォルダ...
-
パソコンで core i3-7020u と c...
-
Oracle で文字列からタイムスリ...
-
oracleの直接接続のクライアン...
-
IPアドレスを数値に変換
-
oracleのsqlについて質問です。...
-
sqlで質問です。 Aテーブルは店...
-
SQLの中上級者へのレベルアップ...
-
SELECTによる表の変換方法を教...
-
開発対象となるアプリケーショ...
-
Oracleですがsqlで質問です。 ...
-
sqlで質問です。 Aテーブルの登...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
あるカラムのMAX値+1をINSERTし...
-
レコードが選択されないときの...
-
Oracle8iでSQL文の引数について
-
複数行を1行にするSQL
-
SQLPLUSにて演算子を使う方法と...
-
Oracle 9iで英字を含まないレコ...
-
ループの仕方
-
PL/SQLの基礎的な質問ですが・・
-
sqlのwhereで指定した条件の前...
-
SQL:外部結合について
-
sumやcount関数について
-
テーブル結合について、下記SQL...
-
教えて下さい。m(__)m
-
SELECT文でINを使わずに検索したい
-
DB2の行指定検索SQLについて
-
外部結合に条件をつけたい
-
複数条件に当てはまる行の抽出...
-
GROUP BYを行った後に結合した...
-
Oracleでの文字列連結サイズの上限
-
OracleのSQL*PLUSで、デー...
おすすめ情報