【MySQL必知必會(huì)】第12章:匯總數(shù)據(jù)

12.1 基本匯總函數(shù)

MySQL提供了基本的聚集函數(shù)砌庄,可以用于求平均值全谤、頻數(shù)等笙什,所謂的聚集函數(shù)(aggregate function):

指運(yùn)行在行組上铜异,計(jì)算和返回單個(gè)值的函數(shù)奶卓。

12.1.1 AVG函數(shù)

使用AVG函數(shù)可以用來求平均值:

SELECT AVG(prod_price) AS avg_price
FROM products;

除此之外网杆,AVG還可以搭配上WHERE子句來查詢特定條件下的平均值哎甲,但有以下兩點(diǎn)可能需要注意的是:

  • AVG每次只能作用單列的平均值著榴,如果想獲得多列的平均值就要多次使用
  • NULL值會(huì)被AVG函數(shù)給忽略

12.1.2 COUNT函數(shù)

使用COUNT函數(shù)可以用來進(jìn)行頻數(shù)統(tǒng)計(jì):

SELECT COUNT(*) AS num_cust
FROM customers;

其中COUNT函數(shù)有兩種使用方式:

  • 一種是COUNT()用來對(duì)行的數(shù)目進(jìn)行計(jì)數(shù)博脑,無論表列中是否包含空值(即不忽略空值*)
  • 另一種是使用COUNT(column)來對(duì)特定的列具有的行進(jìn)行計(jì)數(shù)憎乙,但卻忽略NULL值

12.1.3 MAX和MIN函數(shù)

使用MAX和MIN函數(shù)可以返回列中的最大或最小值:

#最大值
SELECT MAX(prod_price) AS max_price
FROM products;

#最小值
SELECT MIN(prod_price) AS min_price
FROM products;

MAX和MIN函數(shù)有以下幾個(gè)共同之處:

  • 都要求指定列名
  • 可以對(duì)非數(shù)值數(shù)據(jù)使用,例如日期叉趣、文本
  • 都忽略NULL值

12.1.4 SUM函數(shù)

使用SUM函數(shù)可以用來求和:

SELECT SUM(quantity) AS items_ordered
FROM orderitems
WHERE order_num = 20005;

除了對(duì)單個(gè)列求和外泞边,SUM函數(shù)還可以用來合計(jì)計(jì)算值:

SELECT SUM(item_price*quantity) AS total_price
FROM orderitems
WHERE order_num = 20005;

12.2 匯總唯一值

以上聚集函數(shù)都是默認(rèn)指定ALL參數(shù)(所有行),如果想要匯總統(tǒng)計(jì)不重復(fù)的值(唯一值)疗杉,那么就需要額外使用DISTINCT參數(shù):

SELECT AVG(DISTINCT prod_price) AS avg_price
FROM products
WHERE vend_id = 1003;
  • 對(duì)于COUNT函數(shù)阵谚,DISTINCT只能作用于指定列名時(shí),若使用COUNT()則無法起作用*

12.3 匯總組合

以上的示例都是將各個(gè)函數(shù)單獨(dú)拆開時(shí)的用法乡数,其實(shí)可以直接將其作用在同一代碼塊中椭蹄,用逗號(hào)隔開即可:

SELECT COUNT(*) AS num_items,
    MIN(prod_price) AS price_min,
    MAX(prod_price) AS price_max,
    AVG(prod_price) AS price_AVG
FROM products;
  • 但需要注意的是,最后一個(gè)與FROM關(guān)鍵字緊挨著的代碼就不需要使用逗號(hào)隔開
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末净赴,一起剝皮案震驚了整個(gè)濱河市绳矩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌玖翅,老刑警劉巖翼馆,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異金度,居然都是意外死亡应媚,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門猜极,熙熙樓的掌柜王于貴愁眉苦臉地迎上來中姜,“玉大人,你說我怎么就攤上這事《撸” “怎么了翩瓜?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長携龟。 經(jīng)常有香客問我兔跌,道長,這世上最難降的妖魔是什么峡蟋? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任坟桅,我火速辦了婚禮,結(jié)果婚禮上蕊蝗,老公的妹妹穿的比我還像新娘仅乓。我一直安慰自己,他們只是感情好匿又,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布方灾。 她就那樣靜靜地躺著,像睡著了一般碌更。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上洞慎,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天痛单,我揣著相機(jī)與錄音,去河邊找鬼劲腿。 笑死旭绒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的焦人。 我是一名探鬼主播挥吵,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼花椭!你這毒婦竟也來了忽匈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤矿辽,失蹤者是張志新(化名)和其女友劉穎丹允,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體袋倔,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡雕蔽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了宾娜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片批狐。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖前塔,靈堂內(nèi)的尸體忽然破棺而出嚣艇,到底是詐尸還是另有隱情缘眶,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布髓废,位于F島的核電站巷懈,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏慌洪。R本人自食惡果不足惜顶燕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望冈爹。 院中可真熱鬧涌攻,春花似錦、人聲如沸频伤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽憋肖。三九已至因痛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間岸更,已是汗流浹背鸵膏。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留怎炊,地道東北人谭企。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像评肆,于是被迫代替她去往敵國和親债查。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容