sql語(yǔ)句中的case語(yǔ)句與高級(jí)語(yǔ)言中的switch語(yǔ)句,是標(biāo)準(zhǔn)sql的語(yǔ)法,適用于一個(gè)條件判斷有多種值的情況下分別執(zhí)行不同的操作。
首先,讓我們看一下CASE的語(yǔ)法。在一般的SELECT中,其語(yǔ)法格式如下:
SELECT <myColumnSpec> =
CASE <單值表達(dá)式>
when <表達(dá)式值> then <SQL語(yǔ)句或者返回值>
when <表達(dá)式值> then <SQL語(yǔ)句或者返回值>
...
when <表達(dá)式值> then <SQL語(yǔ)句或者返回值>
END
例子(引用):
第一組: 查詢dj_zt表狀態(tài)為'07'或'11'、qylx_dm = '03'的所有記錄數(shù)。
A:用CASE語(yǔ)句
select count(case a.zt when '07' then a.bs end)+
count(case a.zt when '11' then a.bs end)
from dj_zt a
where a.qylx_dm = '03'
----------------
11829
B:不用CASE語(yǔ)句
select count(*)
from dj_zt a
where a.qylx_dm = '03'
and a.zt in ('07', '11')
----------------
11829
結(jié)果:A、B兩組耗費(fèi)的代價(jià)一樣的,相比B的寫法簡(jiǎn)潔,平局。
第二組: 分別查詢dj_zt表狀態(tài)為'07'和'11'且qylx_dm = '03'的所有記錄數(shù)。
A:用CASE語(yǔ)句
select count(case a.zt when '07' then a.bs end),
count(case a.zt when '11' then a.bs end)
from dj_zt a
where a.qylx_dm = '03
----------------
4565 7264
B:不用CASE語(yǔ)句(寫了兩條語(yǔ)句,掃描表兩遍,效率明顯低下)
select count(*)
from dj_zt a
where a.qylx_dm = '03'
and a.zt='07'
----------------
4565
select count(*)
from dj_zt a
where a.qylx_dm = '03'
and a.zt='11'
----------------
7264
結(jié)果:B組代價(jià)明顯高出A組很多,執(zhí)行的效率比較低。
CASE和IF的區(qū)別:
在高級(jí)語(yǔ)言中,CASE的可以用IF來替代,但是在SQL中不行。
CASE是SQL標(biāo)準(zhǔn)定義的,IF是數(shù)據(jù)庫(kù)系統(tǒng)的擴(kuò)展。
CASE可以用于SQL語(yǔ)句和SQL存儲(chǔ)過程、觸發(fā)器,IF只能用于存儲(chǔ)過程和觸發(fā)器。
在SQL過程和觸發(fā)器中,用IF替代CASE代價(jià)都相當(dāng)?shù)母?,相?dāng)?shù)穆闊?,難以實(shí)現(xiàn)。
總結(jié): 通過上面兩組實(shí)例可以看出,應(yīng)用CASE語(yǔ)句可以讓SQL變得簡(jiǎn)潔高效,從而大大提高了執(zhí)行效率。而且,CASE的使用一般不會(huì)引起性能(相比沒有用CASE的語(yǔ)句)低下,反而增加了操作的靈活性
select atid,userid,title,releasedate,ForumId,clicks,istoday = (
case Convert(varchar(10), releasedate,120)
when Convert(varchar(10), getdate(),120)
then releasedate
end),BBSSetTop from Tab_ArticleTopics where ForumId<>0 and status in(1,5)
order by BBSSetTop desc, istoday desc,clicks desc
===========================================
有一張表,里面有3個(gè)字段:語(yǔ)文,數(shù)學(xué),英語(yǔ)。其中有3條記錄分別表示語(yǔ)文70分,數(shù)學(xué)80分,英語(yǔ)58分,請(qǐng)用一條sql語(yǔ)句查詢出這三條記錄并按以下條件顯示出來(并寫出您的思路):
大于或等于80表示優(yōu)秀,大于或等于60表示及格,小于60分表示不及格。
顯示格式:
語(yǔ)文 數(shù)學(xué) 英語(yǔ)
及格 優(yōu)秀 不及格
------------------------------------------
select
(case when 語(yǔ)文>=80 then '優(yōu)秀'
when 語(yǔ)文>=60 then '及格'
else '不及格') as 語(yǔ)文,
(case when 數(shù)學(xué)>=80 then '優(yōu)秀'
when 數(shù)學(xué)>=60 then '及格'
else '不及格') as 數(shù)學(xué),
(case when 英語(yǔ)>=80 then '優(yōu)秀'
when 英語(yǔ)>=60 then '及格'
else '不及格') as 英語(yǔ),
from table
------------------------------------------------------------------------
IF語(yǔ)句的用法
IF(expr1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),則 IF()的返回值為expr2; 否則返回值則為 expr3。IF() 的返回值為數(shù)字值或字符串值,具體情況視其所在語(yǔ)境而定。
mysql> SELECT IF(1>2,2,3);
-> 3
mysql> SELECT IF(1<2,'yes ','no');
-> 'yes'
mysql> SELECT IF(STRCMP('test','test1'),'no','yes');
-> 'no'
如果expr2 或expr3中只有一個(gè)明確是 NULL,則IF() 函數(shù)的結(jié)果類型 為非NULL表達(dá)式的結(jié)果類型。
expr1 作為一個(gè)整數(shù)值進(jìn)行計(jì)算,就是說,假如你正在驗(yàn)證浮點(diǎn)值或字符串值, 那么應(yīng)該使用比較運(yùn)算進(jìn)行檢驗(yàn)。
mysql> SELECT IF(0.1,1,0);
-> 0
mysql> SELECT IF(0.1<>0,1,0);
-> 1
在所示的第一個(gè)例子中,IF(0.1)的返回值為0,原因是 0.1 被轉(zhuǎn)化為整數(shù)值,從而引起一個(gè)對(duì) IF(0)的檢驗(yàn)。這或許不是你想要的情況。在第二個(gè)例子中,比較檢驗(yàn)了原始浮點(diǎn)值,目的是為了了解是否其為非零值。比較結(jié)果使用整數(shù)。
IF() (這一點(diǎn)在其被儲(chǔ)存到臨時(shí)表時(shí)很重要 ) 的默認(rèn)返回值類型按照以下方式計(jì)算:
表達(dá)式
返回值
expr2 或expr3 返回值為一個(gè)字符串。
字符串
expr2 或expr3 返回值為一個(gè)浮點(diǎn)值。
浮點(diǎn)
expr2 或 expr3 返回值為一個(gè)整數(shù)。
整數(shù)
假如expr2 和expr3 都是字符串,且其中任何一個(gè)字符串區(qū)分大小寫,則返回結(jié)果是區(qū)分大小寫。
IFNULL(expr1,expr2)
假如expr1 不為 NULL,則 IFNULL() 的返回值為 expr1; 否則其返回值為 expr2。IFNULL()的返回值是數(shù)字或是字符串,具體情況取決于其所使用的語(yǔ)境。
mysql> SELECT IFNULL(1,0);
-> 1
mysql> SELECT IFNULL(NULL,10);
-> 10
mysql> SELECT IFNULL(1/0,10);
-> 10
mysql> SELECT IFNULL(1/0,'yes');
-> 'yes'
IFNULL(expr1,expr2)的默認(rèn)結(jié)果值為兩個(gè)表達(dá)式中更加“通用”的一個(gè),順序?yàn)镾TRING、 REAL或 INTEGER。假設(shè)一個(gè)基于表達(dá)式的表的情況, 或MySQL必須在內(nèi)存儲(chǔ)器中儲(chǔ)存一個(gè)臨時(shí)表中IFNULL()的返回值:
CREATE TABLE tmp SELECT IFNULL(1,'test') AS test;
在這個(gè)例子中,測(cè)試列的類型為 CHAR(4)。
NULLIF(expr1,expr2)
如果expr1 = expr2 成立,那么返回值為NULL,否則返回值為 expr1。這和CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END相同。
mysql> SELECT NULLIF(1,1);
-> NULL
mysql> SELECT NULLIF(1,2);
-> 1
注意,如果參數(shù)不相等,則 MySQL 兩次求得的值為 expr1
聯(lián)系客服