欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入了解MySQL中聚合函數(shù)的使用

 更新時(shí)間:2022年07月27日 09:12:41   作者:不渴望力量的哈士奇  
這篇文章主要為大家詳細(xì)介紹一下MySQL中聚合函數(shù)的使用,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)MySQL有一定幫助,需要的可以參考一下

今天的章節(jié)我們將要來學(xué)習(xí)一下 “聚合函數(shù)” ;首先我們需要學(xué)習(xí)聚合函數(shù)對(duì)數(shù)據(jù)進(jìn)行統(tǒng)計(jì)分析,比如說求最大值、最小值、平均值之類的場景。但是單純的使用聚合函數(shù),只能做全表范圍的統(tǒng)計(jì)分析。如果想要把記錄分組分別統(tǒng)計(jì),需要使用 “GROUP BY” 和 “HAVING” 這樣的分組子句了。關(guān)于分組查詢的應(yīng)用,將在下一章節(jié)為大家進(jìn)行講解。當(dāng)前章節(jié)我們還是學(xué)習(xí)一下 “聚合函數(shù)” 的基本使用。

什么是聚合函數(shù)

聚合函數(shù)是用來做簡單的數(shù)據(jù)統(tǒng)計(jì)的,比如說統(tǒng)計(jì)一下 “員工表” 中的平均工齡是多少年啊,員工表中一共有多少條記錄等等… 這些都需要使用到聚合函數(shù)。

聚合函數(shù)也被稱為 “匯總函數(shù)” ,在數(shù)據(jù)的查詢分析中,應(yīng)用的十分廣泛。可以幫助我們實(shí)現(xiàn)對(duì)數(shù)據(jù)的求和、求最大值、求最小值、求平均值等等。

如果不指定統(tǒng)計(jì)的范圍,那么聚合函數(shù)統(tǒng)計(jì)的范圍就是整張數(shù)據(jù)表,該章節(jié)我們所講解的 “聚合函數(shù)” 就是針對(duì)整張數(shù)據(jù)表范圍的。

聚合函數(shù)演示案例:(求員工表中的平均月收入是多少?)

SELECT AVG(sal + IFNULL(comm,0)) AS 平均工資
from t_emp;

-- AVG:聚合函數(shù),求平均值使用
-- IFNULL:IFNULL 函數(shù)的語法,當(dāng)?shù)谝粋€(gè)參數(shù)的值為null 的時(shí)候,則返回第二個(gè)參數(shù)的值

PS:需要注意的地方,在聚合函數(shù)的返回結(jié)果集(無論是求和、最大值、最小值、還是求平均數(shù)),結(jié)果集只有一個(gè)返回?cái)?shù)據(jù)。

SUM 函數(shù)

SUN 函數(shù)用于求和,只能用于數(shù)字類型;如果用于字符類型的數(shù)據(jù),則統(tǒng)計(jì)結(jié)果為0;如果用于時(shí)間類型的數(shù)據(jù)的求和,則結(jié)果是毫秒數(shù)的相加。

SQL 語句演示 SUM函數(shù) 案例(統(tǒng)計(jì) 10、20 部門的員工的月薪的總和)

SELECT SUM(sal)
FROM t_emp
WHERE deptno IN (10, 20)

SQL 語句演示 SUM函數(shù) 案例(統(tǒng)計(jì) ename(字段) 的綜合 )

SELECT SUM(ename)
FROM t_emp
WHERE deptno IN (10, 20)

MAX 函數(shù)

MAX 函數(shù)用于獲取非空值的最大值。

SELECT MAX(comm) FROM t_emp;

-- 比如這種想要獲取 "comm" 字段的非空的最大值,直接套一個(gè) MAX() 函數(shù)即可。

SQL 語句演示 MAX函數(shù) 案例(查詢 10、20 部門的月收入最高的員工)

SELECT MAX(sal + IFNULL(comm,0)) AS max_sal
FROM t_emp
WHERE deptno IN (10, 20)

-- MAX:聚合函數(shù),求最大值使用
-- IFNULL:IFNULL 函數(shù)的語法,當(dāng)?shù)谝粋€(gè)參數(shù)的值為null 的時(shí)候,則返回第二個(gè)參數(shù)的值

SQL 語句演示 MAX函數(shù) 案例(查詢 員工姓名 最長的名字的長度)

SELECT MAX(LENGTH(ename)) AS length_ename
FROM t_emp;

-- LENGTH:LENGTH函數(shù)可以統(tǒng)計(jì)字符的個(gè)數(shù)計(jì)算其長度

MIN 函數(shù)

與MAX 函數(shù)對(duì)應(yīng)的是 MIN 函數(shù),用于獲得非空值的最小值。

SQL語句演示 MIN函數(shù) 案例(查詢 員工編號(hào)最小 的員工)

SELECT MIN(empno) AS min_empno
FROM t_emp;

SQL語句演示 MIN函數(shù) 案例(查詢 最早入職 的員工)

SELECT MIN(hiredate) AS min_hiredate
FROM t_emp;

AVG 函數(shù)

在上文我們已經(jīng)演示過了 AVG 函數(shù)的使用方法,AVG 函數(shù)是用于獲得非空值的平均值;如果用于非數(shù)字?jǐn)?shù)據(jù)的統(tǒng)計(jì),輸出結(jié)果為 0 。
聚合函數(shù)演示案例:(求員工表中的平均月收入是多少?)

SELECT AVG(sal + IFNULL(comm,0)) AS 平均工資
from t_emp;

-- AVG:聚合函數(shù),求平均值使用
-- IFNULL:IFNULL 函數(shù)的語法,當(dāng)?shù)谝粋€(gè)參數(shù)的值為null 的時(shí)候,則返回第二個(gè)參數(shù)的值

COUNT 函數(shù)

COUNT 函數(shù)用于獲得記錄的數(shù)量,COUNT 函數(shù)有兩種用法。

第一種:在 COUNT() 函數(shù)的 括號(hào)內(nèi),輸入一個(gè) “*” 即可,記錄下包含空值的查詢記錄的數(shù)量。示例:COUNT(*)

第二種:在 COUNT() 函數(shù)的 括號(hào)內(nèi),輸入要統(tǒng)計(jì)的列名即可,記錄下包含非空值的查詢的記錄的數(shù)量。示例:COUNT(列名)

SQL語句演示 COUNT(*) 案例

SELECT COUNT(*) FROM t_emp;

SQL語句演示 COUNT(列名) 案例

SELECT COUNT(comm) FROM t_emp;

聚合函數(shù)綜合小練習(xí)

聚合函數(shù)綜合練習(xí) -1

SQL 案例1 - 語句演示:(查詢 10、20部門中,底薪超過 2000 并且工齡超過 15年 的員工人數(shù))

SELECT COUNT(*) 
FROM t_emp
WHERE deptno IN (10, 20)
AND sal >= 2000
AND DATEDIFF(NOW(),hiredate)/365 >= 15;

聚合函數(shù)綜合練習(xí) -2

SQL 案例2 - 語句演示:(查詢 1985年之后入職的員工,并且底薪超過公司平均底薪的員工的數(shù)量)

SELECT COUNT(*) 
FROM t_emp
WHERE hiredate >= "1985-01-01"
AND sal >= AVG(sal)

PS:表面上看這個(gè) SQL 是正常的,但是這個(gè) SQL 語是無法得出想要的結(jié)果的,因?yàn)檎Z法上有錯(cuò)誤。WHERE 子句中出現(xiàn)了聚合函數(shù),這一點(diǎn)大家一定要注意,聚合函數(shù) 一定不能出現(xiàn)在 WHERE 子句中。

PS:WHERE 子句中不能出現(xiàn) 聚合函數(shù) 的根本原因還要從 子句的執(zhí)行順序來說起。sql語句的執(zhí)行過程是:from-->where-->group by -->having --- >order by --> select;

PS:聚合函數(shù)是針對(duì)結(jié)果集進(jìn)行的,但是where條件并不是在查詢出結(jié)果集之后運(yùn)行,所以主函數(shù)放在where語句中,會(huì)出現(xiàn)錯(cuò)誤。

PS:關(guān)于如何解決這個(gè)問題,將在下一章節(jié)的 "分組查詢的應(yīng)用" 進(jìn)行詳細(xì)的講解。

以上就是深入了解MySQL中聚合函數(shù)的使用的詳細(xì)內(nèi)容,更多關(guān)于MySQL聚合函數(shù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • mysql大表復(fù)制的具體實(shí)現(xiàn)

    mysql大表復(fù)制的具體實(shí)現(xiàn)

    MySQL大表復(fù)制是指將一個(gè)數(shù)據(jù)庫中的大表復(fù)制到另一個(gè)數(shù)據(jù)庫中,以實(shí)現(xiàn)數(shù)據(jù)的備份或數(shù)據(jù)遷移的目的,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • mysql 5.7.18 Archive壓縮版安裝教程

    mysql 5.7.18 Archive壓縮版安裝教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.18 Archive壓縮版安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • mysql存儲(chǔ)過程中使用游標(biāo)的實(shí)例

    mysql存儲(chǔ)過程中使用游標(biāo)的實(shí)例

    使用MYSQL存儲(chǔ)過程,可以實(shí)現(xiàn)諸多的功能,下面將為您介紹一個(gè)MYSQL存儲(chǔ)過程中使用游標(biāo)的實(shí)例
    2014-01-01
  • mysql判斷字段是否存在的方法

    mysql判斷字段是否存在的方法

    mysql判斷字段是否存在的方法有很多,如使用desc命令、show columns 命令、describe 命令等等,感興趣的朋友可以參考下
    2014-01-01
  • MySQL學(xué)習(xí)之SQL語法及SQL解析順序

    MySQL學(xué)習(xí)之SQL語法及SQL解析順序

    這篇文章主要介紹了SQL語法及SQL解析順序,SQL(Structured Query Language)是一種標(biāo)準(zhǔn),作為一種訪問關(guān)系型數(shù)據(jù)庫的標(biāo)準(zhǔn)語言,感興趣的小伙伴可以借鑒閱讀
    2023-03-03
  • mysql8.0.20配合binlog2sql的配置和簡單備份恢復(fù)的步驟詳解

    mysql8.0.20配合binlog2sql的配置和簡單備份恢復(fù)的步驟詳解

    這篇文章主要介紹了mysql8.0.20配合binlog2sql的配置和簡單備份恢復(fù)的步驟,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • mysql 8.0.16 Win10 zip版本安裝配置圖文教程

    mysql 8.0.16 Win10 zip版本安裝配置圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0 Win10 zip版本安裝配置圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • 詳解MySQL數(shù)據(jù)備份之mysqldump使用方法

    詳解MySQL數(shù)據(jù)備份之mysqldump使用方法

    本篇文章主要介紹了MySQL數(shù)據(jù)備份,詳細(xì)的介紹了mysqldump的各種用法,具有一定的參考價(jià)值,有需要的可以了解一下。
    2016-11-11
  • MySQL中union和unionall區(qū)別

    MySQL中union和unionall區(qū)別

    本文主要介紹了MySQL中union和unionall區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • MySQL事務(wù)控制流與ACID特性

    MySQL事務(wù)控制流與ACID特性

    本文將會(huì)介紹 MySQL 的事務(wù) ACID 特性和 MySQL 事務(wù)控制流程的語法,并介紹事務(wù)并發(fā)處理中可能出現(xiàn)的異常情況,比如臟讀、幻讀、不可重復(fù)讀等等,最后介紹事務(wù)隔離級(jí)別。感興的小伙伴可以一起來學(xué)習(xí)
    2021-08-08

最新評(píng)論