亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SQL Having用法示例小結(jié)

 更新時(shí)間:2024年12月16日 09:46:21   作者:我名字很好聽(tīng)  
這篇文章主要介紹了SQL Having用法示例小結(jié),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧

SQL Having用法

HAVING子句用于過(guò)濾分組之后的數(shù)據(jù)。

1、如果過(guò)濾條件中使用了聚合函數(shù),或行已經(jīng)被分組,則必須使用HAVING來(lái)替換WHERE。否則,報(bào)錯(cuò)。

2、HAVING 必須聲明在 GROUP BY 的后面。

# 查詢各個(gè)部門(mén)中最高工資大于10000的部門(mén)信息
SELECT department_id, MAX(salary) max_salary
FROM employees
GROUP BY department_id
# 對(duì)分組后的數(shù)據(jù)進(jìn)行篩選,選出部門(mén)中最高工資大于10000的部門(mén)
HAVING max_salary > 10000;

開(kāi)發(fā)中,我們使用HAVING的前提是SQL中使用了GROUP BY。 

如果沒(méi)有使用GROUP BY,使用HAVING,則整個(gè)表中的所有記錄會(huì)被當(dāng)成一組,然后對(duì)這一組記錄根據(jù)HAVING中的條件進(jìn)行篩選。

SELECT department_id, MAX(salary) max_salary
FROM employees
HAVING max_salary > 10000;

HAVING 不能單獨(dú)使用,必須要跟 GROUP BY 一起使用。 

1、當(dāng)過(guò)濾條件中有聚合函數(shù)時(shí),則此過(guò)濾條件必須聲明在HAVING中。
2、當(dāng)過(guò)濾條件中沒(méi)有聚合函數(shù)時(shí),則此過(guò)濾條件聲明在WHERE中或HAVING中都可以。但是,建議大家聲明在WHERE中。 

補(bǔ)充:SQL Having用法

拿個(gè)業(yè)務(wù)場(chǎng)景說(shuō)這個(gè)案例,比如我們有個(gè)表里面可能有批改過(guò)的數(shù)據(jù),批改過(guò)得數(shù)據(jù)不會(huì)隨著新批改的數(shù)據(jù)覆蓋,而是逐條插入表中,如果想找出包含最早批改的數(shù)據(jù)和最新批改數(shù)據(jù)的話,那么我們就需要用到了havinng 用法,假設(shè)最開(kāi)始的批單號(hào)是000,批單號(hào)是累加的

比如我們有個(gè)表 table 表里面有兩個(gè)字段 訂單號(hào)(order_no) 和 批單號(hào)(endorseq_no)

那么寫(xiě)法就是

select order_no
from table
group by order_no
having sum(case when endorseq_no = '000' then 1 
                else 0 end) >= 1  --這個(gè)是判斷必須包含最初的批單
  and count(*) >= 2    --這個(gè)是判斷除了最初的批單之外還需要有新批改的批單

到此這篇關(guān)于SQL Having用法的文章就介紹到這了,更多相關(guān)SQL Having 用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論