總結(jié)SQL中的group by 與 having 用法相關(guān)總結(jié)
發(fā)表時(shí)間:2023-07-22 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]這篇文章主要介紹了SQL中的group by 和 having 用法淺析,需要的的朋友參考下吧一、sql中的group by 用法解析: Group By語(yǔ)句從英文的字面意義上理解就是“根據(jù)(by...
這篇文章主要介紹了SQL中的group by 和 having 用法淺析,需要的的朋友參考下吧
一、sql中的group by 用法解析:
Group By語(yǔ)句從英文的字面意義上理解就是“根據(jù)(by)一定的規(guī)則進(jìn)行分組(Group)”。
作用:通過(guò)一定的規(guī)則將一個(gè)數(shù)據(jù)集劃分成若干個(gè)小的區(qū)域,然后針對(duì)若干個(gè)小區(qū)域進(jìn)行數(shù)據(jù)處理。
注意:group by 是先排序后分組!
舉例說(shuō)明:如果要用到group by 一般用到的就是“每”這個(gè)字, 例如現(xiàn)在有一個(gè)這樣的需求:查詢(xún)每個(gè)部門(mén)有多少人。就要用到分組的技術(shù)
select DepartmentID as '部門(mén)名稱(chēng)',COUNT(*) as '個(gè)數(shù)'
from BasicDepartment
group by DepartmentID
這個(gè)就是使用了group by +字段進(jìn)行了分組,其中我們就可以理解為我們按照部門(mén)的名稱(chēng)ID
DepartmentID將數(shù)據(jù)集進(jìn)行了分組;然后再進(jìn)行各個(gè)組的統(tǒng)計(jì)數(shù)據(jù)分別有多少;
二、group by 和having 解釋
前提:必須了解sql語(yǔ)言中一種特殊的函數(shù)——聚合函數(shù)。
例如:SUM, COUNT, MAX, AVG等。這些函數(shù)和其它函數(shù)的根本區(qū)別就是它們一般作用在多條記錄上。
WHERE關(guān)鍵字在使用集合函數(shù)時(shí)不能使用,所以在集合函數(shù)中加上了HAVING來(lái)起到測(cè)試查詢(xún)結(jié)果是否符合條件的作用。
having稱(chēng)為分組過(guò)濾條件,也就是分組需要的條件,所以必須與group by聯(lián)用。
需要注意說(shuō)明:當(dāng)同時(shí)含有where子句、group by 子句 、having子句及聚集函數(shù)時(shí),執(zhí)行順序如下:
1、執(zhí)行where子句查找符合條件的數(shù)據(jù);
2、使用group by 子句對(duì)數(shù)據(jù)進(jìn)行分組;
3、對(duì)group by 子句形成的組運(yùn)行聚集函數(shù)計(jì)算每一組的值;
4、最后用having 子句去掉不符合條件的組。
having 子句中的每一個(gè)元素也必須出現(xiàn)在select列表中。有些數(shù)據(jù)庫(kù)例外,如oracle.
having子句和where子句都可以用來(lái)設(shè)定限制條件以使查詢(xún)結(jié)果滿(mǎn)足一定的條件限制。
having子句限制的是組,而不是行。聚合函數(shù)計(jì)算的結(jié)果可以當(dāng)條件來(lái)使用,where子句中不能使用聚集函數(shù),而having子句中可以。
以上就是總結(jié)SQL中的group by 和 having 用法相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。