
ASPでoracleのデータを集計しようとしたところ、SQL文でエラーが発生してしまいました。
(ORA-00911: 文字が無効です。)
同じSQL文を「SQLPlus Worksheet」で実行してみたら、問題なく実行できました。
エラーの原因を教えてください。
SELECT
CASE
WHEN 処理CD = '1' AND 集計F = 'Y' THEN '1Y'
WHEN 処理CD = '1' AND 集計F <> 'Y' THEN '1N'
END AS kubun,
COUNT(連番) AS kensu
SUM(金額) AS kingaku
FROM aaa
WHERE 日付 = '200701'
GROUP BY
CASE
WHEN 処理CD = '1' AND 集計F = 'Y' THEN '1Y'
WHEN 処理CD = '1' AND 集計F <> 'Y' THEN '1N'
END
kubun毎に金額の合計値などを集計したいというような感じです。
よろしくお願い致します。
No.3ベストアンサー
- 回答日時:
何となくなんですが・・
SELECT DECODE(処理CD,'1',DECODE(集計F,'Y','1Y','1N')) kubun,COUNT(連番) kensu,SUM(金額) kingaku
FROM aaa
WHERE 日付 = '200701'
GROUP BY DECODE(処理CD,'1',DECODE(集計F,'Y','1Y','1N'))
という書き方を試してください。
(あてずっぽのカンがあたっていればなんですけどね)
お礼が遅くなりましてすみません。
出来ました!
何故CASE式が使えないのかは不明ですが・・・
DECODEもGROUP BY句に入れられるんですね。
グループ化するにはCASE式を使わないとダメだと思っていました。
助かりました。ありがとうございました。
No.2
- 回答日時:
No.1です。
後はぱっと見「COUNT(連番) AS kensu」の後に「,」が無い事くらいですかね?
転記する際に間違えられたのかも知れませんが・・・。
はい。すみません。
転記する際に間違えました。
ASPからテキストに吐き出して、SQLで実行してみるというのを試してみます。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
1件あたりの処理時間を検討する...
-
同じSELECT文同士でのデ...
-
object browser で処理を中断す...
-
DELETE文でFROM句を省略した場合
-
PL/SQLの平行処理について
-
同一レコード更新時の排他制御
-
select for updateのロック
-
統計情報の取得=コミットですか?
-
RDBのテーブル種類の違い
-
他の処理でselectさせないよう...
-
accessでイベントを中止するよ...
-
一時表 を表単位で
-
VACUUM ANALYZE の頻度について
-
Oracleの欠点
-
Access2013で操作ログを残した...
-
DBリンクエラーについて
-
データを削除しても表領域の使...
-
Viewにインデックスは張れ...
-
ORA-00959: 表領域'****'は...
-
Access レコードを追加できませ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
DELETE文でFROM句を省略した場合
-
同じSELECT文同士でのデ...
-
RDBのテーブル種類の違い
-
他の処理でselectさせないよう...
-
object browser で処理を中断す...
-
accessでイベントを中止するよ...
-
1件あたりの処理時間を検討する...
-
ActiveX DLLでのオラクルのトラ...
-
年度毎にシーケンスの初期化?
-
PL/SQLの平行処理について
-
チューニング対象のSQLの見つけ...
-
処理速度の見積もり時間について。
-
同一レコード更新時の排他制御
-
Oracleから見たOracleの優位性(...
-
Access2013で操作ログを残した...
-
sysdateの使い方
-
stored procedureの引数について
-
カーソルについて
-
PL/SQLでmdb(Access)ファイルへ...
-
排他制御の仕方
おすすめ情報