SQL文中で全角文字を使うなと言われたので、ORACLEでJOIN句の条件式をCASE文で分岐させる

投稿日:2017-07-28

JOINの条件式にCase文を入れる
http://blog.goo.ne.jp/ilikehobby/e/80b471f96f6d693b6c5df75f18591c0e

SQL文中で全角文字を使うなと言われたので、四苦八苦w

こんなデータに対して、

ID name
1
2
3

「あ」を「か」に、「い」を「き」に・・・って表示を変えたかった。

ID name
1
2
3

ただ、これだけなら、ゴリゴリとCASE文使って書けば良くね?って話だった。
だから、力技でSQLを書いたw

tableBはこんな感じのデータが格納されてるとして、

ID name
1
2
3
select 
  tableA.ID
  ,case when tableB.name = 'あ' then 'か'
       when tableB.name = 'い' then 'き'
            :
       else to_char(tableB.name)
       end
from
  tableA
  left join tableB
    on tableA.ID = tableB.ID

 

こんな感じで、「あ」を「か」に、「い」を「き」に・・・って表示を変えたかった。

ただ、この「あ」とか「か」に相当するものは、ユーザー状況で変化しうる内容で、一定ではないし、そもそもSQL文中に全角文字を指定するとは何事か!!って全否定された訳w

困ったぞ・・・

ということで、調べてたら、どうもJOIN句でもcase文による分岐が使えるみたい。
なので、・・・

select 
  tableA.ID
  ,tableB.name
from
  tableA
  left join tableB
    on case when tableA.ID = 1 then 6
       case when tableA.ID = 2 then 7
           :
       end tableA.ID
        = tableB.ID

こうした。

まぁ、この例だと、単にIDの数に5を足せば目的は達成出来るんだけどねw

今回は、そんな単純なルールじゃなくて、条件を手動で記載せざるを得なかった・・・

 

ただ、分かってて使うか、コメントを残しておかないと、後で分からなくなりそう。

通常の結合であれば、主キーだったりの結合で、基本的には同一のキーに対応するデータが取得できるけど、これをやると、後で結果だけ見たときに、IDに対して明らかに異なる結果が返ってくるので・・・

自分もだけど、まぁ、コメント残しても読まないやつは読まないから、最終的にはSQL自体を調査することになりますがw

次の修正が発生したときに、自分に回ってこないよう祈ろう・・・







-ORACLE, PC
-, ,


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

「TeamViewerが商用環境で使用されているようです。」と表示され、使えなくなった時の対処法。

突然表示された「商用使用の疑い」 いきなりでした。 ちょうど、先週ぐらいにTeamViewerのセッションが突然切れるということが発生。 その時は、気にせず再接続しようとしたら、商用使用の疑いとのこと …

SRWare Ironの起動時に「プロフィールを開くことができませんでした。・・・」と表示されて起動できない問題。

窓際社員として1日を平和に過ごすには、ネットの力は必要なんです。 退屈しのぎ(調べ物)する事もあるし、それこそ仕事の内容を検索して時間を潰し(一生懸命仕事してる)ので。   ところが、先日か …

VMWareがだめだったから、VirtualBoxでUbuntuを使おうとして駄目だった話。

日本の中心付近で仕様変更と闘うSE日記VMWare導入したかったけど、断念した話。http://ht-jp.net/blog/pc/vmware-ubuntuなんとなく仕事でPGをやり続けるのに気が重 …

次はSSDではなく、HDDを買わなきゃいけないかもしれない事態になった。

先日、サブPCが起動直後にフリーズするという事態に陥ったため、システムドライブのSSDを新品のSSDに換装しました。 日本の中心付近で仕様変更と闘うSE日記SSDを追加購入:SUNDISK SDSSD …

Oracleで「ORA-00906: 左カッコがありません。」のエラーが出た時の対処法

はい。 そろそろ、上司の無茶目な仕様変更にも折り合いをつけて行きたいSEっぽいことをやってる人です。 前にも書いたかもしれないけど、また、どハマリしたOracleのエラーについて。 エラーの内容が全て …


カテゴリー