CASE陳述句是SQL-92內標準SQL。SQL大師權威Joe Celko認為CASE陳述式或許是SQL-92最為有用的功能之一。本文主要講解CASE語法。當熟練後,不僅能讓SQL語法更加靈活,也能減少許多沉長的語句。
CASE可分為單純CASE陳述式(simple case)
CASE
WHEN condition THEN result
[WHEN···]
[ELSE result]
END;
和搜尋CASE陳述式(searched case)
CASE expression
WHEN value THEN result
[WHEN···]
[ELSE result]
END;
注意
- 各分條件傳回的資料類型必須一致
- 記得加上END
- 一定要撰寫ELSE陳述句
我們看看如何使用case來減少SQL語法撰寫。
–條件1
Update Employee
SET salary = salary * 0.9
WHERE salary >= 30000
–條件2
Update Employee
SET salary = salary * 1.2
WHERE salary >= 25000 AND salary < 28000
現在我們改用CASE
UPDATE Employee
SET salary = CASE WHEN salary >= 30000
THEN salary * 0.9
WHEN salary >= 25000 AND salary < 28000
THEN salary * 1.2
ELSE salary END;
上例顯示正確使用case只須執行一次SQL有助於提升效能
再提出兩個例子
例子1
表:sq1Q1
data:image/s3,"s3://crabby-images/c90c3/c90c398442e106d8f7edcf5b16eac5bcbfca0bf5" alt="This image has an empty alt attribute; its file name is caseSQL1.png"
試者從這張資料表取得x與y的最大值
SQL語法為:
data:image/s3,"s3://crabby-images/1841e/1841e733be154ba24c41ea0fed2d8b798e1cd40c" alt="This image has an empty alt attribute; its file name is caseSQL6.png"
結果為
data:image/s3,"s3://crabby-images/78ee4/78ee444317e7f979a6378badbd0d9e180ee96bdc" alt="This image has an empty alt attribute; its file name is caseSQL2-1.png"
例子2
表: PopTbl2
data:image/s3,"s3://crabby-images/66b24/66b24ecf1260575b0c7aff933a51b141fcbd3b10" alt="This image has an empty alt attribute; its file name is caseSQL3.png"
請製作總結果以及欄位的交叉分析表
SQL語法為:
data:image/s3,"s3://crabby-images/c18bd/c18bda4ade7e83a3dd36a16c71f9d8162eeb949a" alt="This image has an empty alt attribute; its file name is caseSQL4.png"
data:image/s3,"s3://crabby-images/a282c/a282c593aa3ca29c85f9c447a2ac44236033c0ee" alt="This image has an empty alt attribute; its file name is caseSQL5.png"
熟練CASE語句是DBA人員必備的條件,期望本文能提供些幫助。