SQL集合函式中case when then 使用技巧
我們都知道SQL中使用case when then來轉化資料庫中的資訊 比如 select (case sex when 0 then '男' else '女' end) AS sex from studentInfo
假設資料庫有一張表名為student的表。
如果現在要你根據這張表,查出江西省男女個數,廣東省男生個數,浙江省男女個數 怎麼寫SQL語句?即要生成下結果表
答案是:select sex ,count ( case province when '廣東省' then '廣東省' end )as 廣東省 ,count ( case province when '江西省' then '江西省' end )as 江西省 ,count ( case province when '浙江省' then '浙江省' end )as 浙江省 from student group by sex
count()函式即根據給定的範圍和group by(統計方式) 而統計行資料的條數
我們一步步來理解上面語句
1. select sex from student (查詢資料表中的存在的男女條數)
2.select sex, count (*) as num from student group by sex (查詢表中男女數量)
3.select sex ,province, count (*)as num from student group by sex,province (查詢各省男女數量)
重點來了,如果我把count(*) 中的 *號換成任一列名呢? 如count(province) 會怎樣?
4.select sex ,province, count (province)as num from student group by sex,province (查詢各省男女數量)
結果跟上圖一樣:這說明換不換都一樣。又有count (province)等價於 count(case province when '浙江省' then '浙江省' else province end )
但是如果我們縮小範圍呢即count(case province when '浙江省' then '浙江省' end ) 那麼請看下面
5.select sex ,province, count ( case province when '浙江省' then '浙江省' end )as num from student group by sex,province
即統計男女數量範圍限定在浙江省 再精簡一下即下面
6.select sex, count ( case province when '浙江省' then '浙江省' end ) as 浙江省 from student group by sex
已經接近我們的要求了,現在只要加上另幾個欄位就是了
7.select sex ,count ( case province when '廣東省' then '廣東省' end )as 廣東省 ,count ( case province when '江西省' then '江西省' end )as 江西省 ,count ( case province when '浙江省' then '浙江省' end )as 浙江省 from student group by sex
小結:當然實現有很多種方法 可以多個子查詢拼接起來也不無可厚非。我這只是一種思路
補充:case when then 知識點
(1) select (case province when '浙江省' then '浙江' when '江西省' then '江西' end ) as 省份 from student
如果預設範圍如果沒全包含則為空 像上圖的廣東省為空
(2)select (case province when '浙江省' then '浙江' when '江西省' then '江西' else province end ) as 省份 from student