首頁 資料庫 mysql教程 转: SQLServer Case具有两种格式:简单Case函数和Case搜索函数

转: SQLServer Case具有两种格式:简单Case函数和Case搜索函数

Jun 07, 2016 pm 03:12 PM
case sqlserver 函數 格式 簡單

转载自: http://blog.csdn.net/IBM_hoojo/article/details/5546868 Case 具有 两种 格式 。 简单 Case 函数 和Case 搜索 函数 。 -- 简单 Case 函数 CASE sex WHEN ' 1 ' THEN ' 男 ' WHEN ' 2 ' THEN ' 女 ' ELSE ' 其他 ' END -- Case 搜索 函数 CASE WHE

转载自: http://blog.csdn.net/IBM_hoojo/article/details/5546868

Case具有两种格式简单Case函数和Case搜索函数。 
-- 简单Case函数
CASE  sex
         
WHEN   ' 1 '   THEN   ' '
         
WHEN   ' 2 '   THEN   ' '
ELSE   ' 其他 '   END
-- Case搜索函数
CASE   WHEN  sex  =   ' 1 '   THEN   ' '
         
WHEN  sex  =   ' 2 '   THEN   ' '
ELSE   ' 其他 '   END

这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。 
还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。 
-- 比如说,下面这段SQL,你永远无法得到“第二类”这个结果
CASE   WHEN  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   ' 其他 '   END
FROM     Table_A
GROUP   BY   CASE  country
                
WHEN   ' 中国 '       THEN   ' 亚洲 '
                
WHEN   ' 印度 '       THEN   ' 亚洲 '
                
WHEN   ' 日本 '       THEN   ' 亚洲 '
                
WHEN   ' 美国 '       THEN   ' 北美洲 '
                
WHEN   ' 加拿大 '    THEN   ' 北美洲 '
                
WHEN   ' 墨西哥 '    THEN   ' 北美洲 '
        
ELSE   ' 其他 '   END ;

同样的,我们也可以用这个方法来判断工资的等级,并统计每一等级的人数。SQL代码如下; 
SELECT
        
CASE   WHEN  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 '
        
ELSE   NULL   END  salary_class,
        
COUNT ( * )
FROM     Table_A
GROUP   BY
        
CASE   WHEN  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 '
        
ELSE   NULL   END ;

二,用一个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 CASE   WHEN  sex  =   ' 1 '   THEN  
                      population 
ELSE   0   END ),   -- 男性人口
        SUM CASE   WHEN  sex  =   ' 2 '   THEN  
                      population 
ELSE   0   END )    -- 女性人口
FROM   Table_A
GROUP   BY  country;

这样我们使用Select,完成对二维表的输出形式,充分显示了Case函数的强大。 

三,在Check中使用Case函数。 

在Check中使用Case函数在很多情况下都是非常不错的解决方法。可能有很多人根本就不用Check,那么我建议你在看过下面的例子之后也尝试一下在SQL中使用Check。 
下面我们来举个例子 
公司A,这个公司有个规定,女职员的工资必须高于1000块。如果用Check和Case来表现的话,如下所示 
CONSTRAINT  check_salary  CHECK
           ( 
CASE   WHEN  sex  =   ' 2 '
                  
THEN   CASE   WHEN  salary  >   1000
                        
THEN   1   ELSE   0   END
                  
ELSE   1   END   =   1  )

如果单纯使用Check,如下所示 
CONSTRAINT  check_salary  CHECK
           ( sex 
=   ' 2 '   AND  salary  >   1000  )

女职员的条件倒是符合了,男职员就无法输入了。 



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mysql和sqlserver語法有什麼差別 mysql和sqlserver語法有什麼差別 Apr 22, 2024 pm 06:33 PM

MySQL 和 SQL Server 的語法差異主要體現在資料庫物件、資料類型、SQL 語句和其他方面。資料庫物件差異包括儲存引擎和檔案群組的指定方式、索引和約束的建立。資料類型差異涉及數值類型、字元類型和日期時間類型的差異。 SQL 語句差異體現在結果集限制、資料插入、更新和刪除操作等方面。其他差異還包括識別列、視圖和預存程序的建立方式。了解這些差異對於使用不同的資料庫系統時避免錯誤非常重要。

golang函數動態建立新函數的技巧 golang函數動態建立新函數的技巧 Apr 25, 2024 pm 02:39 PM

Go語言提供了兩種動態函數創建技術:closures和反射。 closures允許存取閉包作用域內的變量,而反射可使用FuncOf函數建立新函數。這些技術在自訂HTTP路由器、實現高度可自訂的系統和建置可插拔的元件方面非常有用。

C++ 函數命名中參數順序的考慮 C++ 函數命名中參數順序的考慮 Apr 24, 2024 pm 04:21 PM

在C++函數命名中,考慮參數順序至關重要,可提高可讀性、減少錯誤並促進重構。常見的參數順序約定包括:動作-物件、物件-動作、語意意義和遵循標準函式庫。最佳順序取決於函數目的、參數類型、潛在混淆和語言慣例。

如何在Java中寫出高效和可維護的函數? 如何在Java中寫出高效和可維護的函數? Apr 24, 2024 am 11:33 AM

編寫高效且可維護的Java函數的關鍵在於:保持簡潔。使用有意義的命名。處理特殊情況。使用適當的可見性。

excel函數公式大全 excel函數公式大全 May 07, 2024 pm 12:04 PM

1. SUM函數,用於對一列或一組單元格中的數字進行求和,例如:=SUM(A1:J10)。 2、AVERAGE函數,用於計算一列或一組儲存格中的數字的平均值,例如:=AVERAGE(A1:A10)。 3.COUNT函數,用於計算一列或一組單元格中的數字或文字的數量,例如:=COUNT(A1:A10)4、IF函數,用於根據指定的條件進行邏輯判斷,並返回相應的結果。

C++ 函式預設參數與可變參數的優缺點比較 C++ 函式預設參數與可變參數的優缺點比較 Apr 21, 2024 am 10:21 AM

C++函數中預設參數的優點包括簡化呼叫、增強可讀性、避免錯誤。缺點是限制靈活性、命名限制。可變參數的優點包括無限彈性、動態綁定。缺點包括複雜性更高、隱式型別轉換、除錯困難。

navicat資料庫檔案在哪 navicat資料庫檔案在哪 Apr 23, 2024 am 10:57 AM

Navicat 資料庫設定檔的儲存位置因作業系統而異:Windows:使用者特定路徑為%APPDATA%\PremiumSoft\Navicat\macOS:使用者特定路徑為~/Library/Application Support/Navicat\Linux:使用者特定路徑為~/ .config/navicat\設定檔名稱包含連線類型,如navicat_mysql.ini。這些設定檔儲存資料庫連線資訊、查詢歷史記錄和 SSH 設定。

自訂 PHP 函數和預定義函數之間有什麼區別? 自訂 PHP 函數和預定義函數之間有什麼區別? Apr 22, 2024 pm 02:21 PM

自訂PHP函數與預定義函數的差異在於:作用域:自訂函數僅限於其定義範圍,而預定義函數可在整個腳本中存取。定義方式:自訂函數使用function關鍵字定義,而預先定義函數則由PHP核心定義。參數傳遞:自訂函數接收參數,而預先定義函數可能不需要參數。擴充性:自訂函數可以根據需要創建,而預定義函數是內建的且無法修改。

See all articles