免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
select case when的一些用法以及IF的用法

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

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
我的MYSQL學(xué)習(xí)心得(六) 函數(shù)
mysql中IFNULL
mysql使用if...else...來查詢
case when 方法總結(jié)
MS SQL,Oracle, MySQL查出值為NULL的替換
MySQL IFNULL()函數(shù)用法
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服