一、MySQL case when的三種用法: 1.case 欄位 when, 欄位的具體值; 2.case when 欄位,可對欄位進行取值範圍設置; 3.case when 欄位1,欄位2,可對多個欄位進行取值映射; 註:如果兩個條件都針對一個欄位的話,會顯示第一個when的值。 二、具體解釋: ...
一、MySQL case when的三種用法:
1.case 欄位 when, 欄位的具體值;
select a.*,
case sex
when '1' then '男'
else '女'
end as '性別'
FROM table_sex a;
2.case when 欄位,可對欄位進行取值範圍設置;
SELECT a.*,
CASE
WHEN a.age BETWEEN 0 and 20 THEN '青年'
WHEN a.age BETWEEN 20 and 40 THEN '中年'
ELSE '非人類'
END AS '描述'
FROM table_c a;
3.case when 欄位1,欄位2,可對多個欄位進行取值映射;
SELECT a.*,
CASE
WHEN a.age BETWEEN 20 and 80 THEN '青年'
WHEN a.name ='流浪' THEN '帥氣'
END AS '描述'
FROM table_cc a
註:如果兩個條件都針對一個欄位的話,會顯示第一個when的值。
二、具體解釋:
SELECT
case -------------如果
when sex='1' then '男' -------------sex='1',則返回值'男'
when sex='2' then '女' -------------sex='2',則返回值'女'
else 0 -------------其他的返回'其他’
end -------------結束
from sys_user --------整體理解: 在sys_user表中如果sex='1',則返回值'男'如果sex='2',則返回值'女' 否則返回'其他’
三、例子
有員工表如下:
empinfo (
Fempno varchar2(10) not null pk,
Fempname varchar2(20) not null,
Fage number not null,
Fsalary number not null
);
假如數據量很大約1000萬條;
寫一個你認為最高效的SQL,用一個SQL計算以下四種人:
- fsalary>9999 and fage > 35
- fsalary>9999 and fage < 35
- fsalary <9999 and fage > 35
- fsalary <9999 and fage < 35
每種員工的數量
SELECT
SUM(CASE WHEN fsalary > 9999 AND fage > 35 THEN 1 ELSE 0 END)
AS "fsalary>9999_fage>35",
SUM(CASE WHEN fsalary > 9999 AND fage < 35 THEN 1 ELSE 0 END)
AS "fsalary>9999_fage<35",
SUM(CASE WHEN fsalary < 9999 AND fage > 35 THEN 1 ELSE 0 END)
AS "fsalary<9999_fage>35",
SUM(CASE WHEN fsalary < 9999 AND fage < 35 THEN 1 ELSE 0 END)
AS "fsalary<9999_fage<35"
FROM empinfo;
END 2018-05-16 14:30:48