乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      select case when的一些用法以及IF的用法

       cqxujun 2013-04-18

      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來(lái)替代,但是在SQL中不行。
      CASE是SQL標(biāo)準(zhǔn)定義的,IF是數(shù)據(jù)庫(kù)系統(tǒng)的擴(kuò)展。
      CASE可以用于SQL語(yǔ)句和SQL存儲(chǔ)過(guò)程、觸發(fā)器,IF只能用于存儲(chǔ)過(guò)程和觸發(fā)器。
      在SQL過(guò)程和觸發(fā)器中,用IF替代CASE代價(jià)都相當(dāng)?shù)母?,相?dāng)?shù)穆闊?,難以實(shí)現(xiàn)。


      總結(jié): 通過(guò)上面兩組實(shí)例可以看出,應(yīng)用CASE語(yǔ)句可以讓SQL變得簡(jiǎn)潔高效,從而大大提高了執(zhí)行效率。而且,CASE的使用一般不會(huì)引起性能(相比沒(méi)有用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ǔ)句查詢出這三條記錄并按以下條件顯示出來(lái)(并寫出您的思路): 
         大于或等于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ì)算,就是說(shuō),假如你正在驗(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

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多