1. ホーム
  2. sql

[解決済み】SQL Serverで入れ子のcase文ロジックを行う最適な方法

2022-04-12 06:56:06

質問

SQLクエリを書いているのですが、返されるカラムのいくつかは、かなり多くの条件に応じて計算される必要があります。

現在、入れ子にしたcase文を使っていますが、ごちゃごちゃしてきました。より良い(より整理された、あるいは読みやすい)方法はないでしょうか?

(Microsoft SQL Server, 2005 を使用しています)


簡略化した例です。

SELECT
    col1,
    col2,
    col3,
    CASE
        WHEN condition 
        THEN
            CASE
                WHEN condition1 
                THEN
                    CASE 
                        WHEN condition2
                        THEN calculation1
                        ELSE calculation2
                    END
                ELSE
                    CASE 
                        WHEN condition2
                        THEN calculation3
                        ELSE calculation4
                    END
            END
        ELSE 
            CASE 
                WHEN condition1 
                THEN 
                    CASE
                        WHEN condition2 
                        THEN calculation5
                        ELSE calculation6
                    END
                ELSE
                    CASE
                        WHEN condition2 
                        THEN calculation7
                        ELSE calculation8
                    END
            END            
    END AS 'calculatedcol1',
    col4,
    col5 -- etc
FROM table

解決方法は?

ある種のCOALESCEトリックを試すことができます。

select coalesce(
  CASE WHEN condition1 THEN calculation1 ELSE NULL END,
  CASE WHEN condition2 THEN calculation2 ELSE NULL END,
  など
)