Case具有兩種格式。簡(jiǎn)單Case函數(shù)和Case搜索函數(shù)。
--簡(jiǎn)單Case函數(shù)CASEsexWHEN'1'THEN'男'WHEN'2'THEN'女'ELSE'其他'END--Case搜索函數(shù)CASEWHENsex ='1'THEN'男'WHENsex ='2'THEN'女'ELSE'其他'END
這兩種方式,可以實(shí)現(xiàn)相同的功能。簡(jiǎn)單Case函數(shù)的寫法相對(duì)比較簡(jiǎn)潔,但是和Case搜索函數(shù)相比,功能方面會(huì)有些限制,比如寫判斷式。
還有一個(gè)需要注意的問題,Case函數(shù)只返回第一個(gè)符合條件的值,剩下的Case部分將會(huì)被自動(dòng)忽略。
--比如說,下面這段SQL,你永遠(yuǎn)無法得到“第二類”這個(gè)結(jié)果
CASE WHEN col_1 IN('a','b') THEN '第一類' WHEN col_1 IN('a') THEN '第二類'? ELSE '其他'END
我們也可以用這個(gè)方法來判斷工資的等級(jí),并統(tǒng)計(jì)每一等級(jí)的人數(shù)。SQL代碼如下;
SELECT
CASE WHEN salary <= 500? THEN'1'
WHEN salary > 500 AND salary <= 600 THEN '2'
WHEN salary > 600 AND salary <= 800 THEN '3'
WHEN salary > 800 AND salary<=1000 THEN '4'
ELSE NULL END salary_class,COUNT(*)
FROM Table_A GROUP BY
CASE WHEN salary <= 500 THEN'1'
WHEN salary > 500 AND salary <= 600 THEN'2'
WHEN salary > 600 AND salary <= 800 THEN'3'
WHEN salary > 800 AND salary <= 1000 THEN'4' ELSE NULL END;