校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > SQL集合函數中case when then 使用技巧

SQL集合函數中case when then 使用技巧

熱門標簽:最新人工智能電銷機器人 如何做地圖標注圖鋪 al智能電話機器人 數字匠心電銷機器人 成都電話外呼系統一般多少錢 銀川高頻外呼回撥系統多少錢 沒聽見電話機器人幫你接 蘭州語音外呼系統運營商 陜西電銷外呼系統好用嗎

那么在集合函數中它有什么用呢 ?

假設數據庫有一張表名為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

您可能感興趣的文章:
  • MySQL 的CASE WHEN 語句使用說明
  • sql學習之CASE WHEN THEN ELSE END的用法
  • MySQL的CASE WHEN語句的幾個使用實例
  • MySQL中使用case when 語句實現多條件查詢的方法
  • sql 中 case when 語法使用方法
  • 淺析SQL語句行列轉換的兩種方法 case...when與pivot函數的應用
  • sum(case when then)(判斷男女生的個數)
  • mysql case when group by 實例詳解
  • 關于case when語句的報錯問題詳解
  • MySQL排序中使用CASE WHEN的方法示例

標簽:邢臺 遼源 宜春 通化 朔州 鹽城 本溪 巴彥淖爾

巨人網絡通訊聲明:本文標題《SQL集合函數中case when then 使用技巧》,本文關鍵詞  SQL,集合,函數,中,case,when,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL集合函數中case when then 使用技巧》相關的同類信息!
  • 本頁收集關于SQL集合函數中case when then 使用技巧的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 萨迦县| 维西| 仙居县| 莱州市| 堆龙德庆县| 通江县| 浑源县| 万盛区| 婺源县| 康定县| 千阳县| 岐山县| 沅江市| 庆城县| 措美县| 澎湖县| 高碑店市| 禄丰县| 清流县| 甘德县| 青岛市| 镇江市| 蒙自县| 镇康县| 星子县| 嘉义县| 耿马| 兖州市| 屏南县| 合水县| 衡阳县| 盐池县| 荣成市| 张家口市| 西和县| 七台河市| 夏邑县| 五河县| 莎车县| 金阳县| 福泉市|