SQL Case when 的使用方法

来源:http://www.cnblogs.com/toyz/archive/2017/01/20/6323168.html
-Advertisement-
Play Games

Case具有兩種格式。簡單Case函數和Case搜索函數。 這兩種方式,可以實現相同的功能。簡單Case函數的寫法相對比較簡潔,但是和Case搜索函數相比,功能方面會有些限制,比如寫判斷式。 還有一個需要註意的問題,Case函數只返回第一個符合條件的值,剩下的Case部分將會被自動忽略。 下麵我們來 ...


Case具有兩種格式。簡單Case函數和Case搜索函數。

--簡單Case函數CASE sex
WHEN'1'THEN'男'WHEN'2'THEN'女'ELSE'其他'END--Case搜索函數CASEWHEN sex = '1'THEN'男'WHEN sex = '2'THEN'女'ELSE'其他'END


這兩種方式,可以實現相同的功能。簡單Case函數的寫法相對比較簡潔,但是和Case搜索函數相比,功能方面會有些限制,比如寫判斷式。 
還有一個需要註意的問題,Case函數只返回第一個符合條件的值,剩下的Case部分將會被自動忽略。 

--比如說,下麵這段SQL,你永遠無法得到“第二類”這個結果CASEWHEN col_1 IN ( 'a', 'b') THEN'第一類'WHEN col_1 IN ('a')       THEN'第二類'ELSE'其他'END


下麵我們來看一下,使用Case函數都能做些什麼事情。 

一,已知數據按照另外一種方式進行分組,分析。 

有如下數據:(為了看得更清楚,我並沒有使用國家代碼,而是直接用國家名作為Primary Key) 

國家(country) 人口(population)
中國 600
美國 100
加拿大 100
英國 200
法國 300
日本 250
德國 200
墨西哥 50
印度 250


根據這個國家人口數據,統計亞洲和北美洲的人口數量。應該得到下麵這個結果。 

人口
亞洲 1100
北美洲 250
其他 700


想要解決這個問題,你會怎麼做?生成一個帶有洲Code的View,是一個解決方法,但是這樣很難動態的改變統計的方式。 
如果使用Case函數,SQL代碼如下:

SELECT  SUM(population),
CASE country
WHEN'中國'THEN'亞洲'WHEN'印度'THEN'亞洲'WHEN'日本'THEN'亞洲'WHEN'美國'THEN'北美洲'WHEN'加拿大'THEN'北美洲'WHEN'墨西哥'THEN'北美洲'ELSE'其他'ENDFROM    Table_A
GROUPBYCASE country
WHEN'中國'THEN'亞洲'WHEN'印度'THEN'亞洲'WHEN'日本'THEN'亞洲'WHEN'美國'THEN'北美洲'WHEN'加拿大'THEN'北美洲'WHEN'墨西哥'THEN'北美洲'ELSE'其他'END;


同樣的,我們也可以用這個方法來判斷工資的等級,並統計每一等級的人數。SQL代碼如下; 

SELECTCASEWHEN salary <= 500 THEN'1'WHEN salary > 500 AND salary <= 600  THEN'2'WHEN salary > 600 AND salary <= 800  THEN'3'WHEN salary > 800 AND salary <= 1000 THEN'4'ELSENULLEND salary_class,
COUNT(*)
FROM    Table_A
GROUPBYCASEWHEN salary <= 500 THEN'1'WHEN salary > 500 AND salary <= 600  THEN'2'WHEN salary > 600 AND salary <= 800  THEN'3'WHEN salary > 800 AND salary <= 1000 THEN'4'ELSENULLEND;


二,用一個SQL語句完成不同條件的分組。 

有如下數據 

國家(country) 性別(sex) 人口(population)
中國 1 340
中國 2 260
美國 1 45
美國 2 55
加拿大 1 51
加拿大 2 49
英國 1 40
英國 2 60


按照國家和性別進行分組,得出結果如下 

國家
中國 340 260
美國 45 55
加拿大 51 49
英國 40 60


普通情況下,用UNION也可以實現用一條語句進行查詢。但是那樣增加消耗(兩個Select部分),而且SQL語句會比較長。 
下麵是一個是用Case函數來完成這個功能的例子 

SELECT country,
SUM( CASEWHEN sex = '1'THEN
population ELSE 0 END),  --男性人口
SUM( CASEWHEN sex = '2'THEN
population ELSE 0 END)   --女性人口FROM  Table_A
GROUPBY country;


這樣我們使用Select,完成對二維表的輸出形式,充分顯示了Case函數的強大。 

三,在Check中使用Case函數。 

在Check中使用Case函數在很多情況下都是非常不錯的解決方法。可能有很多人根本就不用Check,那麼我建議你在看過下麵的例子之後也嘗試一下在SQL中使用Check。 
下麵我們來舉個例子 
公司A,這個公司有個規定,女職員的工資必須高於1000塊。如果用Check和Case來表現的話,如下所示

CONSTRAINT check_salary CHECK
( CASEWHEN sex = '2'THENCASEWHEN salary > 1000
THEN 1 ELSE 0 ENDELSE 1 END = 1 )


如果單純使用Check,如下所示 

CONSTRAINT check_salary CHECK
( sex = '2'AND salary > 1000 )

關註流行國外網站

facebook:http://www.fb-on.com

facebook官網:http://www.facebookzh.com

facebook:http://www.cn-face-book.com

youtube:http://www.youtubezh.com

twitter:http://www.twitterzh.com

 


女職員的條件倒是符合了,男職員就無法輸入了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java代碼 Java代碼 關註流行國外網站 facebook:http://www.fb-on.com facebook官網:http://www.facebookzh.com facebook:http://www.cn-face-book.com youtube:http://www.yout ...
  • AlwaysOn是在SQL Server 2012中新引入的一種高可用技術,從名稱中可以看出,AlwaysOn的設計目標是保持資料庫系統永遠可用。AlwaysOn利用了Windows伺服器故障轉移集群(Windows Server Failover Clustering,簡稱WSFC)的健康檢測和自 ...
  • /*僅返回一個結果集,且該結果只有很窄的幾列想要以單個文本文件來保存返回結果返回多個結果集,但該結果比較小,且不需要使用多個滾動條就可以在同一頁面上查看多個結果集。*/ ...
  • 一、前言 今天天氣很好,大晴天,心情也好好的。就將MySQL常用的語句總結一下,記錄在隨筆里,也順便分享分享。日後,這篇隨筆我將會持續更新,作為我自己的MySQL語句大全。 二、常用SQL語句 我將由外到里進行編寫(資料庫到表再到數據) 庫層: 1、SHOW DATABASES; 2、CREATE ...
  • 這是一本書的名字,叫做【Hadoop大數據分析與挖掘實戰】,我從2017.1開始學習 軟體版本為Centos6.4 64bit,VMware,Hadoop2.6.0,JDK1.7. 但是這本書的出版時間為2016.1,待到我2017.1使用時,一部分內容已經發生了翻天覆地的變化。 於是我開始寫這麼一... ...
  • pyspark 包介紹 子包 pyspark.sql module pyspark.streaming module pyspark.ml package pyspark.mllib package 子包 pyspark.sql module pyspark.streaming module pys ...
  • Redis簡介 Redis是用C語言開發的一個開源的高性能鍵值對(key-value)資料庫。它通過提供多種鍵值數據類型來適應不同場景下的存儲需求,目前為止Redis支持的鍵值數據類型如 下: 字元串類型(String) 哈希類型(hash) 列表類型(list) 集合類型(set) 有序集合類型( ...
  • 前言 本篇文章寫在新春佳節前夕,也是給IT運維朋友一個警醒,在春節長假前請妥善體檢自己的系統安心過個年。 千里之堤毀於蟻穴,一條看似簡單的語句就能拖垮整個系統,您的SQL Server很久沒體檢了吧? 就像一塊藏著刀片的蛋糕!怎能安度春節? 日誌暴增的問題處理過很多,這隻是很常規的一次,但是對於不是 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...