SQL集合函數(shù)中case when then 使用技巧
那么在集合函數(shù)中它有什么用呢 ?
假設(shè)數(shù)據(jù)庫(kù)有一張表名為student的表。

如果現(xiàn)在要你根據(jù)這張表,查出江西省男女個(gè)數(shù),廣東省男生個(gè)數(shù),浙江省男女個(gè)數(shù) 怎么寫(xiě)SQL語(yǔ)句?即要生成下結(jié)果表

答案是: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()函數(shù)即根據(jù)給定的范圍和group by(統(tǒng)計(jì)方式) 而統(tǒng)計(jì)行數(shù)據(jù)的條數(shù)
我們一步步來(lái)理解上面語(yǔ)句
1. select sex from student (查詢數(shù)據(jù)表中的存在的男女條數(shù))

2.select sex, count (*) as num from student group by sex (查詢表中男女?dāng)?shù)量)

3.select sex ,province, count (*)as num from student group by sex,province (查詢各省男女?dāng)?shù)量)

重點(diǎn)來(lái)了,如果我把count(*) 中的 *號(hào)換成任一列名呢? 如count(province) 會(huì)怎樣?
4.select sex ,province, count (province)as num from student group by sex,province (查詢各省男女?dāng)?shù)量)
結(jié)果跟上圖一樣:這說(shuō)明換不換都一樣。又有count (province)等價(jià)于 count(case province when '浙江省' then '浙江省' else province end )
但是如果我們縮小范圍呢即count(case province when '浙江省' then '浙江省' end ) 那么請(qǐng)看下面
5.select sex ,province, count ( case province when '浙江省' then '浙江省' end )as num from student group by sex,province

即統(tǒng)計(jì)男女?dāng)?shù)量范圍限定在浙江省 再精簡(jiǎn)一下即下面
6.select sex, count ( case province when '浙江省' then '浙江省' end ) as 浙江省 from student group by sex

已經(jīng)接近我們的要求了,現(xiàn)在只要加上另幾個(gè)字段就是了
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

小結(jié):當(dāng)然實(shí)現(xiàn)有很多種方法 可以多個(gè)子查詢拼接起來(lái)也不無(wú)可厚非。我這只是一種思路
補(bǔ)充:case when then 知識(shí)點(diǎn)
(1) select (case province when '浙江省' then '浙江' when '江西省' then '江西' end ) as 省份 from student

如果默認(rèn)范圍如果沒(méi)全包含則為空 像上圖的廣東省為空
(2)select (case province when '浙江省' then '浙江' when '江西省' then '江西' else province end ) as 省份 from student

相關(guān)文章
未公開(kāi)的SQL Server口令的加密函數(shù)
未公開(kāi)的SQL Server口令的加密函數(shù)...2006-07-07
Sql Server中一個(gè)表2個(gè)字段關(guān)聯(lián)同一個(gè)表(代碼解決)
Sql Server中一個(gè)表2個(gè)字段關(guān)聯(lián)同一個(gè)表(代碼解決),需要的朋友可以參考一下2013-02-02
SQL Server ltrim(rtrim()) 去不掉空格的原因分析
這篇文章主要介紹了SQL Server ltrim(rtrim()) 去不掉空格的原因分析,原因主要是因?yàn)橹虚g存在回車符或者換行符,所以要先將此符號(hào)替換掉,具體示例代碼大家參考下本文2017-08-08
OBJECTPROPERTY與sp_rename更改對(duì)象名稱的介紹
開(kāi)發(fā)過(guò)程中,錯(cuò)誤免不了。為了糾正錯(cuò)誤與規(guī)范化??梢允褂肕S SQL Server的系統(tǒng)存儲(chǔ)過(guò)程sp_rename與OBJECTPROPERTY來(lái)更改重命名2012-01-01
在Windows XP系統(tǒng)安裝SQL server 2000 企業(yè)版(圖解版)
今天在網(wǎng)上下載一個(gè)軟件,需要使用MS SQL,海波用的是 Windows XP Professional(專業(yè)) 版系統(tǒng),而SQL卻是企業(yè)版。安裝的時(shí)候提示我只能安裝客戶端,服務(wù)程序卻不能安裝。海波在網(wǎng)上搜索到了一些方法,設(shè)置成功了2014-07-07
SQL Server 事務(wù),異常和游標(biāo)詳解
這篇文章主要為大家介紹了SQLServer事務(wù),異常和游標(biāo),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-01-01

