
SQL文のOrder by句で2つのバインド変数を用いて、ソートする項目・ソート順を決めたいと思い、以下のようなSQLを作成いたしました。
Select row_Number() Over(Order by
Case :ITEM
When 'PJコード' then PJコード
When '部署コード' then 部署コード
end
Case :LINE
When '1' then DESC
When '2' then ASC
end ....
バインド変数を直接Order by句に入れますと、結果は帰ってくるのですが、バインド変数の値がすべて無視されてデータが出力されます。
以上の理由より、Case文にてバインド変数の値を参照し、ソートする項目と順番を決めております。
上記のソースで実行しますとORA-00907:右かっこがありませんというエラーが表示されます。
2つ目のCase文(:LINE)を消し、最初のCase文だけを残して、並び順(DESC・ASC)を埋め込むと、実行される状態になります。
Oracleのバージョンは11gです。
ご回答よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
Order by 項目名 asc/desc
で、項目名に case文は、使えるけど、
asc/desc にcase文は使えません。
(1つ目のCase文は項目名を指定しているのと同じで、1レコードずつ処理されて同じCase文の結果を
1レコードづつ返していると思うけど、内部処理の話なのではっきりしたことはわかりません。)
>2つ目のCase文(:LINE)を消し、最初のCase文だけを残して、並び順(DESC・ASC)を埋め込むと、
>実行される状態になります。
では、デフォルトのascが適用されて実行できている。
じゃあどうすれば実現できるのかといわれると、
SQLを発行している元の処理が何かわからないので最善かどうかはわかりませんが、
SQLで実行するなら、
Select case :LINE when '1' then
(row_Number() Over(Order by
Case :ITEM
When 'PJコード' then PJコード
When '部署コード' then 部署コード
end
desc)
when '2'
(row_Number() Over(Order by
Case :ITEM
When 'PJコード' then PJコード
When '部署コード' then 部署コード
end
asc)
end
....
とでもするしかないと思います。
※未検証。
この回答への補足
先ほどのお礼でエラーが発生すると書きましたが、かっこの位置が間違えたまま実行しておりまして、エラーが発生しておりました。
大変申し訳ありません。
かっこの位置を正しいものに修正し、再度実行したところ、目的としているソートができるようになりました。
ご回答、ありがとうございました。
ご回答ありがとうございます。
返信が遅くなり、申し訳ございません。
ご回答していただきました方法でSQL文を再構築いたしましたが、DESC・ASCを入れると、”右かっこがありません"のエラーメッセージが発生して、SQL文が実行できませんでした…
試しにDESC・ASCを外して実行するとSQL文が発行し、:ITEMで指定した項目でソートできました。
やはりバインド変数でDESC・ASCを決定するのは無理なのかもしれません…
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Access終了時の最適化が失敗?
-
Excelで、改行がある場合の条件...
-
accessのフォームで製品番号と...
-
エクセルの出力方法で
-
実績累計の求め方と意味を教え...
-
Accessで別テーブルの値をフォ...
-
DB2につきまして
-
決定性有限オートマトン
-
【アクセスVBA】テーブルにフィ...
-
エクセルでのマッチング(ちょ...
-
さくらレンタルサーバのMysqlの...
-
アクセスとファイルメーカでは...
-
SQLが組めません…
-
抽出したデータを修正して元の...
-
キーが同じを複数行を1行にま...
-
oracleのinsert select性能
-
関係演算子が無効です。
-
ある条件を持たないレコードの抽出
-
Accessで一致したデータを表示...
-
accessからexcelへのエクスポー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Access終了時の最適化が失敗?
-
CREATE テーブルでの複数外部...
-
Order by句でバインド変数を使...
-
沿線コード
-
Access2000の重複チェック
-
SQL文の書き方
-
10営業日前の日付を取得したい...
-
また正規形について。
-
DLookupの設定で・・・
-
ヤマト急便のチェックデジット...
-
Access Dlookup関数について
-
Access2007 データ型エラーに...
-
SQLの題材
-
WordPress(ワードプレス)に関...
-
困っています。ORACLE_SQL 複数...
-
oracleでは出来るけど、access2...
-
平成20年 春期 基本情報技術者 ...
-
XPアップロード後のアクセスの...
-
Excelファイルのデータをテーブ...
-
【SQL】またぎデータの検索の仕方
おすすめ情報