SQL 中having 和where的區(qū)別分析
在select語句中可以使用groupby子句將行劃分成較小的組,然后,使用聚組函數(shù)返回每一個(gè)組的匯總信息,另外,可以使用having子句限制返回的結(jié)果集。groupby子句可以將查詢結(jié)果分組,并返回行的匯總信息Oracle按照groupby子句中指定的表達(dá)式的值分組查詢結(jié)果。
在帶有g(shù)roupby子句的查詢語句中,在select列表中指定的列要么是groupby子句中指定的列,要么包含聚組函數(shù)
selectmax(sal),jobempgroupbyjob;
(注意max(sal),job的job并非一定要出現(xiàn),但有意義)
查詢語句的select和groupby,having子句是聚組函數(shù)唯一出現(xiàn)的地方,在where子句中不能使用聚組函數(shù)。
selectdeptno,sum(sal)fromempwheresal>1200groupbydeptnohavingsum(sal)>8500orderbydeptno;
當(dāng)在gropuby子句中使用having子句時(shí),查詢結(jié)果中只返回滿足having條件的組。在一個(gè)sql語句中可以有where子句和having子句。having與where子句類似,均用于設(shè)置限定條件
where子句的作用是在對(duì)查詢結(jié)果進(jìn)行分組前,將不符合where條件的行去掉,即在分組之前過濾數(shù)據(jù),條件中不能包含聚組函數(shù),使用where條件顯示特定的行。
having子句的作用是篩選滿足條件的組,即在分組之后過濾數(shù)據(jù),條件中經(jīng)常包含聚組函數(shù),使用having條件顯示特定的組,也可以使用多個(gè)分組標(biāo)準(zhǔn)進(jìn)行分組。
查詢每個(gè)部門的每種職位的雇員數(shù)
selectdeptno,job,count(*)fromempgroupbydeptno,job;
如果你對(duì)何時(shí)應(yīng)該使用WHERE,何時(shí)使用HAVING仍舊很迷惑,請(qǐng)遵照下面的說明:
WHERE語句在GROUPBY語句之前;SQL會(huì)在分組之前計(jì)算WHERE語句。
HAVING語句在GROUPBY語句之后;SQL會(huì)在分組之后計(jì)算HAVING語句。
相關(guān)文章
sql?server設(shè)置數(shù)據(jù)庫某個(gè)字段值不能重復(fù)兩種方法
sqlserver的表中有一個(gè)列不能有相同的值,如何保證每次插入該列的值都是不同的,這篇文章主要給大家介紹了關(guān)于sql?server設(shè)置數(shù)據(jù)庫某個(gè)字段值不能重復(fù)的兩種方法,需要的朋友可以參考下2023-11-11
SQLServer日志清空語句(sql2000,sql2005,sql2008)
時(shí)候當(dāng)系統(tǒng)運(yùn)行時(shí)間比較長(zhǎng)的時(shí)候,我們把備份的數(shù)據(jù)庫還原的時(shí)候發(fā)現(xiàn),數(shù)據(jù)庫中數(shù)據(jù)文件和日志文件變的好大,特別是日志文件?,F(xiàn)在給大家介紹如何清理SQLServer數(shù)據(jù)庫日志2013-05-05
sql中的 where 、group by 和 having 用法解析
這篇文章主要介紹了sql中的 where 、group by 和 having 用法解析,需要的朋友可以參考下2017-04-04
SqlServer使用 case when 解決多條件模糊查詢問題
這篇文章主要介紹了SqlServer使用 case when 解決多條件模糊查詢問題 的相關(guān)資料,需要的朋友可以參考下2015-12-12
SQL Server日志過大會(huì)影響查詢結(jié)果
一臺(tái)老Web服務(wù)器上,使用的是ASP+SQL Server 2000的網(wǎng)站,五六年了,使用起來一直很順暢,也就沒有怎么去理它。2009-05-05

