MySQLでIFを使いたい時はCASE構文を使う

フィールドに入っている値で判別していろいろやりたいときにはCASEを使うと便利でした。例えば、値によってORDER BYで並び替えをしたい場合など。
例えばフィールドkanaに入っている値が””,NULL,ア,イだったとします。50音昇順に並び替えたい場合、ORDER BY kanaとすると、””(空),NULL,ア,イと並びます。ア,イを先にだしたいのにも関わらず!
そこで、CASE構文を使って””とNULLのときには擬似的に別の値を入れて順番を操作してみます。
select * case when furigana='' then 'ン' when furigana is NULL then 'ン' else furigana end as furigana2 from master order by furigana2
caseで条件を入れて、furigana2に値を代入して、並び替えに使っています。furiganaが空かNULLの時には「ン」と入れて最後尾にまわすようにしています。こうすると、順番を操作できます。
[sc name=”engeneer”]
SHARE
スキルアップにMENTA
MENTAはいろんなプロに相談できるNo1メンターサービスです。
僕自身もプロダクトの壁打ち・相談にのっています。個人開発でもコードレビュー、セキュリティ面のチェック、デザイン、広告、コンテンツマーケ、SNS集客について相談する、など使えます。
YouTubeでも発信中!
PROFILE

入江 慎吾
あらゆるスキルが学べるパーソナルメンターサービスMENTAの代表/個人開発が好きでこれまでに30個ほどのWEBサービスやアプリを作ってきました/福岡のWEB制作会社勤務→フリーランスエンジニア→法人立ち上げ→M&A億単位の売却を経験。 (詳しいプロフィール)
あらゆるスキルが学べるパーソナルメンターサービスMENTAの代表/個人開発が好きでこれまでに30個ほどのWEBサービスやアプリを作ってきました/福岡のWEB制作会社勤務→フリーランスエンジニア→法人立ち上げ→M&A億単位の売却を経験。 (詳しいプロフィール)