Mysql count+if 函數(shù)結(jié)合使用

涉及函數(shù)

count函數(shù)

mysql中count函數(shù)用于統(tǒng)計(jì)數(shù)據(jù)表中的行的總數(shù),或者根據(jù)查詢結(jié)果統(tǒng)計(jì)某一列包含的行數(shù),常見(jiàn)的用法如下 count(*) 計(jì)算表的總行數(shù),包括空值 count(字段名) 計(jì)算指定列下的總行數(shù),忽略空值(這點(diǎn)很重要,后面我們將利用這個(gè)特性)

if(expr, v1, v2)函數(shù)

if(expr, v1, v2) 函數(shù)的意思是,如果表達(dá)式expr為true(expr<>0 and expr <> NULL),則if()返回的是v1,否則返回v2

組合上述兩個(gè)函數(shù),可以在一條語(yǔ)句中統(tǒng)計(jì)出滿足不同條件的行數(shù)

業(yè)務(wù)場(chǎng)景:在一個(gè)表中記錄了不同出版社所擁有的所有的書,以及每本書對(duì)應(yīng)的類型。

表結(jié)構(gòu)如下:?

id? ? press? ? ? ? ? ? bookName? ? ? ? ? ? ? ? ? ? ? bookTyoe?


1? ? ? 新華出版社? 《Thinking in Java》? ? 計(jì)算機(jī)類


現(xiàn)需統(tǒng)計(jì)出不同出版社的里面不同類型的書籍的總量

例:統(tǒng)計(jì)不同出版社中文學(xué)類書籍?dāng)?shù)量

select count( if( bookTyoe = ‘文學(xué)類’, id, null ) ) from table group by press

分析:當(dāng)type=1時(shí),會(huì)返回對(duì)應(yīng)的id的值,否則放回null,對(duì)于指定列的count函數(shù),null是被忽略的,這樣就得到了我們想要的統(tǒng)計(jì)數(shù)量了。?

同理,統(tǒng)計(jì)不同出版社中科幻類+計(jì)算機(jī)書籍?dāng)?shù)量:

select count( if( bookTyoein (‘科幻類’, ‘計(jì)算機(jī)書籍’), id, null ) ) from table group by press

如果是聯(lián)表查詢,返回結(jié)果中的id不是唯一的話,想要去掉重復(fù)的id再統(tǒng)計(jì),還可以在if前面加上DISTINCT,即 count( DISTINCT if( type in (2, 3), id, null ) )

等效寫法 count( DISTINCT (type = 2? and? type = 3)? or null )?

也可以使用sum+if替代上述寫法

select sum( if( bookTyoeinin (‘科幻類’, ‘計(jì)算機(jī)書籍’), 1, 0 ) )from table group by press

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 【優(yōu)化】COUNT(1)、COUNT(*)、COUNT(常量)、COUNT(主鍵)、COUNT(ROWID)、CO...
    小麥苗DB寶閱讀 2,841評(píng)論 0 3
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 4,010評(píng)論 0 11
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚_t_閱讀 34,638評(píng)論 18 399
  • 50個(gè)常用的sql語(yǔ)句Student(S#,Sname,Sage,Ssex) 學(xué)生表Course(C#,Cname...
    哈哈海閱讀 1,334評(píng)論 0 7
  • 今天站樁總是感到心口到嗓子這一道深一點(diǎn)的地方很哽硬難受。隨著觀察這種哽硬有時(shí)接下來(lái)連著打嗝一會(huì)。出了一點(diǎn)汗。抖動(dòng)有...
    張德芬幸福驛站咸陽(yáng)閱讀 292評(píng)論 0 0

友情鏈接更多精彩內(nèi)容