轉 ORACLE CASE WHEN 及 SELECT CASE WHEN的用法
例,有如下更新條件
- 工資5000以上的職員,工資減少10%
- 工資在2000到4600之間的職員,工資增加15%
--條件1
UPDATE Personnel SET salary = salary * 0.9
WHERE salary >= 5000;
--條件2
UPDATE Personnel SET salary = salary * 1.15
WHERE salary >= 2000 AND salary < 4600;
但是事情沒有想象得那麼簡單,假設有個人工資5000塊。首先,按照條件1,工資減少10%,變成工資4500。接下來執行第二個SQL時候,因為這個人的工資是4500在2000到4600的範圍之內, 需增加15%,最後這個人的工資結果是5175,不但沒有減少,反而增加了。如果要是反過來執行,那麼工資4600的人相反會變成減少工資。暫且不管這個規章是多麼荒誕,如果想要一個SQL 語句實現這個功能的話,我們需要用到Case函式。程式碼如下:
UPDATEPersonnel
SET salary =
CASE WHEN salary >= 5000 THEN salary * 0.9
WHEN salary >= 2000 AND salary < 4600 THEN salary * 1.15
ELSE salary END;
這裡要注意一點,最後一行的ELSE salary是必需的,要是沒有這行,不符合這兩個條件的人的工資將會被寫成NUll,那可就大事不妙了。在Case函式中Else部分的預設值是NULL,這點是需要注意的地方。
這種方法還可以在很多地方使用,比如說變更主鍵這種累活。
一般情況下,要想把兩條資料的Primary key,a和b交換,需要經過臨時儲存,拷貝,讀回資料的三個過程,要是使用Case函式的話,一切都變得簡單多了。
p_key | col_1 | col_2 |
a | 1 | 張三 |
b | 2 | 李四 |
c | 3 | 王五 |
假設有如上資料,需要把主鍵
a
和b
相互交換。用Case函式來實現的話,程式碼如下UPDATE SomeTable
SET p_key = CASE WHEN p_key = 'a' THEN 'b'
WHEN p_key = 'b' THEN 'a' ELSE p_key END
WHERE p_key IN ('a', 'b');
同樣的也可以交換兩個Unique key。需要注意的是,如果有需要交換主鍵的情況發生,多半是當初對這個表的設計進行得不夠到位,建議檢查表的設計是否妥當。
五,兩個表資料是否一致的檢查。
Case函式不同於DECODE函式。在Case函式中,可以使用BETWEEN,LIKE,IS NULL,IN,EXISTS等等。比如說使用IN,EXISTS,可以進行子查詢,從而 實現更多的功能。
下面具個例子來說明,有兩個表,tbl_A,tbl_B,兩個表中都有keyCol列。現在我們對兩個表進行比較,tbl_A中的keyCol列的資料如果在tbl_B的keyCol列的資料中可以找到, 返回結果'Matched',如果沒有找到,返回結果'Unmatched'。
要實現下面這個功能,可以使用下面兩條語句
--使用IN的時候
SELECT keyCol,
CASE WHEN keyCol IN ( SELECT keyCol FROM tbl_B ) THEN 'Matched'
ELSE 'Unmatched' END Label
FROM tbl_A;
--使用EXISTS的時候
SELECT keyCol,
CASE WHEN EXISTS ( SELECT * FROM tbl_B WHERE tbl_A.keyCol = tbl_B.keyCol ) THEN 'Matched' ELSE 'Unmatched' END Label
FROM tbl_A;
使用IN和EXISTS的結果是相同的。也可以使用NOT IN和NOT EXISTS,但是這個時候要注意NULL的情況。
六,在Case函式中使用合計函式
假設有下面一個表
學號(std_id) | 課程ID(class_id) | 課程名(class_name) | 主修flag(main_class_flg) |
100 | 1 | 經濟學 | Y |
100 | 2 | 歷史學 | N |
200 | 2 | 歷史學 | N |
200 | 3 | 考古學 | Y |
200 | 4 | 計算機 | N |
300 | 4 | 計算機 | N |
400 | 5 | 化學 | N |
500 | 6 | 數學 | N |
有的學生選擇了同時修幾門課程(100,200)也有的學生只選擇了一門課程(300,400,500)。選修多門課程的學生,要選擇一門課程作為主修,主修flag裡面寫入 Y。只選擇一門課程的學生,主修flag為N(實際上要是寫入Y的話,就沒有下面的麻煩事了,為了舉例子,還請多多包含)。
現在我們要按照下面兩個條件對這個表進行查詢
- 只選修一門課程的人,返回那門課程的ID
- 選修多門課程的人,返回所選的主課程ID
簡單的想法就是,執行兩條不同的SQL語句進行查詢。
條件1
--條件1:只選擇了一門課程的學生 SELECT std_id, MAX(class_id) AS main_class FROM Studentclass GROUP BY std_id HAVING COUNT(*) = 1;
執行結果1
STD_ID MAIN_class
300 4
400 5
500 6
條件2
--條件2:選擇多門課程的學生 SELECT std_id, class_id AS main_class FROM Studentclass WHERE main_class_flg = 'Y' ;
執行結果2
STD_ID MAIN_class
100 1
200 3
如果使用Case函式,我們只要一條SQL語句就可以解決問題,具體如下所示
SELECT std_id,
CASE
WHEN COUNT(*) = 1 --只選擇一門課程的學生的情況 THEN MAX(class_id)
ELSE
MAX(CASE WHEN main_class_flg = 'Y' THEN class_id ELSE NULL END )
END AS main_class
FROM Studentclass GROUP BY std_id;
執行結果
STD_ID MAIN_class
100 1
200 3
300 4
400 5
500 6
通過在Case函式中巢狀Case函式,在合計函式中使用Case函式等方法,我們可以輕鬆的解決這個問題。使用Case函式給我們帶來了更大的自由度。
最後提醒一下使用Case函式的新手注意不要犯下面的錯誤
CASE col_1
WHEN 1 THEN 'Right'
WHEN NULL THEN 'Wrong'
END
在這個語句中When Null這一行總是返回unknown,所以永遠不會出現Wrong的情況。因為這句實際表達的意思是
WHEN col_1 = NULL,這是一個錯誤的用法,這個時候我們應該選擇用WHEN col_1 IS NULL。
——————————————————————————————————————————————————————
SELECT CASE WHEN 的用法
select 與 case結合使用最大的好處有兩點,一是在顯示查詢結果時可以靈活的組織格式,二是有效避免了多次對同一個表或幾個表的訪問。下面舉個簡單的例子來說明。例如表 students(id, name ,birthday, sex, grade),要求按每個年級統計男生和女生的數量各是多少,統計結果的表頭為,年級,男生數量,女生數量。如果不用select case when,為了將男女數量並列顯示,統計起來非常麻煩,先確定年級資訊,再根據年級取男生數和女生數,而且很容易出錯。用select
case when寫法如下:
SELECT grade,COUNT(CASE WHEN sex = 1THEN 1 /*sex 1為男生,2位女生*/
ELSE NULL
END) 男生數,
COUNT(CASE WHEN sex = 2THEN 1
ELSE NULL
END) 女生數
FROM students GROUP BY grade;
相關推薦
轉 ORACLE CASE WHEN 及 SELECT CASE WHEN的用法
四,根據條件有選擇的UPDATE。 例,有如下更新條件 工資5000以上的職員,工資減少10%工資在2000到4600之間的職員,工資增加15% 很容易考慮的是選擇執行兩次UPDATE語句,如下所示--條件1 UPDATE Personnel SET salary = salary * 0.9 WH
ORACLE CASE WHEN 及 SELECT CASE WHEN的用法
CASE 語句CASE selector WHEN value1 THEN action1; WHEN value2 THEN action2; WHEN value3 THEN action3; ….. ELSE actionN;END CASE; CA
CASE WHEN 及 SELECT CASE WHEN的用法、SUM函式中的數字引數(轉)
Case具有兩種格式。簡單Case函式和Case搜尋函式。 簡單Case函式 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END --Case搜尋函式 CASE WHEN sex = '1' THEN
CASE WHEN 及 SELECT CASE WHEN的用法
最大 但是 nio decode content src between primary ffffff Case具有兩種格式。簡單Case函數和Case搜索函數。 簡單Case函數 CASE sex WHEN ‘1‘ THEN ‘男‘ WHEN
CASE WHEN 及 SELECT CASE WHEN的用法(寫了一坨爛代碼發現兩條sql就完成了, 哎)
IT 最大 圖片 prim 動態 date 出錯 返回 接下來 轉自:http://blog.sina.com.cn/s/blog_4c538f6c01012mzt.html Case具有兩種格式。簡單Case函數和Case搜索函數。 簡單Case函數
Oracle select case when
對比 設計 搜索 性別 primary 忽略 oracl 數據 from Case具有兩種格式。簡單Case函數和Case搜索函數。 --簡單Case函數 CASE sex WHEN ‘1‘ THEN ‘男‘ WHEN ‘2‘ THEN ‘女‘ ELSE ‘
oracle菜鳥學習之 select case when的使用
com 結束 bstr .com 第一個 rom The 表格 num [toc] oracle菜鳥學習之 select case when的使用 格式語法 case when 條件1 then action1 when 條件2 then action2
SQL:select case when(轉)
CASE 可能是 SQL 中被誤用最多的關鍵字之一。雖然你可能以前用過這個關鍵字來建立欄位,但是它還具有更多用法。例如,你可以在 WHERE 子句中使用 CASE。 首先讓我們看一下 CASE 的語法。在一般的 SELECT 中,其語法如下: SELECT<myColumnSpec>= CAS
Oracle select case when 語法
假如目前我們有一張表 SQL> select * from a ; ONE TWO 1 1 1 2 3 9 2
交叉報表列頭排序時遇到的oracle問題—oracle ORA-12704:字符集不匹配、varchar2轉化為nvarchar2字元缺失、case when else後的字元型別要一致
在做交叉報表列頭的排序時,遇到這三個問題,下面具體來說一下。 設計的資料庫的表結構如圖1所示: 圖1 要處出來student_name_,s.grade_,s.subject_name_,這三個屬性,當時我是這樣寫的sql語句: select s.student_nam
SQL語句 select case when (轉)
CASE 可能是 SQL 中被誤用最多的關鍵字之一。雖然你可能以前用過這個關鍵字來建立欄位,但是它還具有更多用法。例如,你可以在 WHERE 子句中使用 CASE。 首先讓我們看一下 CASE 的語法。在一般的 SELECT 中,其語法如下: SELECT<myColu
oracle--聚合函數和case when結合使用
AS lse 3.4 ont The bsp 分享 div HA 需求: 1 根據客戶信息表中信息比較出相應余額。 2 表中有客戶號,余額,各個時間點的分區信息,每個分區中客戶號唯一。 3 客戶信息中分區有10、11、12、13、14、15。 4 得到每個比上日余額信息,如
ORACLE sql 執行順序、Case When 、檢視執行的sql語句
標準的 SQL 的解析順序為: (1) FROM 子句, 組裝來自不同資料來源的資料 (2) WHERE 子句, 基於指定的條件對記錄進行篩選 (3) GROUP BY 子句, 將資料劃分為多
case...when...then if 用法 select case when if 的一些用法
select case when if 的一些用法 概述:sql語句中的case語句與高階語言中的switch語句,是標準sql的語法,適用於一個條件判斷有多種值的情況下分別執行不同的操作。 首先,讓我們看一下CASE的語法。在一般的SELECT中,其語法格式如下: CASE&nb
Oracle中decode函式對case when的簡化
現假設我們有一個使用者表t_user,其中擁有一個表示性別的欄位gender,該欄位對應的值可能為0、1或者空,其中0表示“男”,1表示“女”,空表示“未填”。現需要我們在查詢t_user的gender時不是顯示對應的0和1,而是顯示對應的文字,“男”或“女”。
Oracle中sum函式和case when聯合使用,報“ORA-00923: 未找到要求的 FROM 關鍵字”錯誤
在做行轉列的時候,一直報“ORA-00923: 未找到要求的 FROM 關鍵字”,找了好久的錯,現記錄下來以便以後檢視。需求是這樣的:按系(系名)分段統計(成績小於 60 分,60-85 分, 85 分以上)“大學物理”課程各分數段的學生人數,及各系學生的平均成績。附上出錯時
select case when where having用法
CASE 可能是 SQL 中被誤用最多的關鍵字之一。雖然你可能以前用過這個關鍵字來建立欄位,但是它還具有更多用法。例如,你可以在 WHERE 子句中使用 CASE。首先讓我們看一下 CASE 的語法。在一般的 SELECT 中,其語法如下:SELECT <myColum
mysql中LOCATE和CASE WHEN...THEN...ELSE...END結合用法
else case put asdf span 項目 oos bstr col 之前項目中需要寫一個sql,就是查出某個調研詳情中,選A答案,B答案,C答案...F答案的人各有多少人,這個sql也是費了很大的力氣才寫出來,故記下來,方便以後使用。 其中tbl_researc
MySql 中 case when then else end 的用法
sta 結束 name cas ber sel 如果 user num MySql 中 case when then else end 的用法 解釋: SELECT case ----------
MySql 中關鍵字 case when then else end 的用法
img closed sta bsp sql hid not weight one 解釋: 1 SELECT 2 case -------------如果 3 when sex=‘1‘ then