欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

SQL中where子句與having子句的區(qū)別有哪些

這篇文章主要介紹了SQL中where子句與having子句的區(qū)別有哪些,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都網(wǎng)絡(luò)公司-成都網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司10余年經(jīng)驗(yàn)成就非凡,專業(yè)從事成都網(wǎng)站建設(shè)、網(wǎng)站制作,成都網(wǎng)頁設(shè)計(jì),成都網(wǎng)頁制作,軟文發(fā)布平臺(tái)1元廣告等。10余年來已成功提供全面的成都網(wǎng)站建設(shè)方案,打造行業(yè)特色的成都網(wǎng)站建設(shè)案例,建站熱線:18980820575,我們期待您的來電!

Where和Having都是對(duì)查詢結(jié)果的一種篩選,說的書面點(diǎn)就是設(shè)定條件的語句。SQL中where子句與having子句的區(qū)別。

1.where 不能放在GROUP BY 后面

2.HAVING 是跟GROUP BY 連在一起用的,放在GROUP BY 后面,此時(shí)的作用相當(dāng)于WHERE

3.WHERE 后面的條件中不能有聚集函數(shù),比如SUM(),AVG()等,而HAVING 可以
Where和Having都是對(duì)查詢結(jié)果的一種篩選,說的書面點(diǎn)就是設(shè)定條件的語句。下面分別說明其用法和異同點(diǎn)。注:本文使用字段為oracle數(shù)據(jù)庫(kù)中默認(rèn)用戶scott下面的emp表,sal代表員工工資,deptno代表部門編號(hào)。

一、聚合函數(shù)

說明前我們先了解下聚合函數(shù):聚合函數(shù)有時(shí)候也叫統(tǒng)計(jì)函數(shù),它們的作用通常是對(duì)一組數(shù)據(jù)的統(tǒng)計(jì),比如說求最大值,最小值,總數(shù),平均值(
MAX,MIN,COUNT, AVG)等。這些函數(shù)和其它函數(shù)的根本區(qū)別就是它們一般作用在多條記錄上。簡(jiǎn)單舉個(gè)例子:SELECT SUM(sal) FROM emp,這里的SUM作用是統(tǒng)計(jì)emp表中sal(工資)字段的總和,結(jié)果就是該查詢只返回一個(gè)結(jié)果,即工資總和。通過使用GROUP BY 子句,可以讓SUM 和 COUNT 這些函數(shù)對(duì)屬于一組的數(shù)據(jù)起作用。

二、where子句

where自居僅僅用于從from子句中返回的值,from子句返回的每一行數(shù)據(jù)都會(huì)用where子句中的條件進(jìn)行判斷篩選。where子句中允許使用比較運(yùn)算符(>,<,>=,<=,<>,!=|等)和邏輯運(yùn)算符(and,or,not)。由于大家對(duì)where子句都比較熟悉,在此不在贅述。

三、having子句

having子句通常是與order by 子句一起使用的。因?yàn)閔aving的作用是對(duì)使用group by進(jìn)行分組統(tǒng)計(jì)后的結(jié)果進(jìn)行進(jìn)一步的篩選。舉個(gè)例子:現(xiàn)在需要找到部門工資總和大于10000的部門編號(hào)?

第一步:

select deptno,sum(sal) from emp group by deptno;

篩選結(jié)果如下:

DEPTNO SUM(SAL)
—— ———-
30 9400
20 10875
10 8750

可以看出我們想要的結(jié)果了。不過現(xiàn)在我們?nèi)绻胍块T工資總和大于10000的呢?那么想到了對(duì)分組統(tǒng)計(jì)結(jié)果進(jìn)行篩選的having來幫我們完成。

第二步:

select deptno,sum(sal) from emp group by deptno having sum(sal)>10000;

篩選結(jié)果如下:

DEPTNO SUM(SAL)
—— ———-
20 10875

當(dāng)然這個(gè)結(jié)果正是我們想要的。

四、下面我們通過where子句和having子句的對(duì)比,更進(jìn)一步的理解它們。

在查詢過程中聚合語句(sum,min,max,avg,count)要比having子句優(yōu)先執(zhí)行,簡(jiǎn)單的理解為只有有了統(tǒng)計(jì)結(jié)果后我才能執(zhí)行篩選。where子句在查詢過程中執(zhí)行優(yōu)先級(jí)別優(yōu)先于聚合語句(sum,min,max,avg,count),因?yàn)樗且痪湟痪浜Y選的。HAVING子句可以讓我們篩選成組后的對(duì)各組數(shù)據(jù)篩選。,而WHERE子句在聚合前先篩選記錄。如:現(xiàn)在我們想要部門號(hào)不等于10的部門并且工資總和大于8000的部門編號(hào)?

我們這樣分析:通過where子句篩選出部門編號(hào)不為10的部門,然后在對(duì)部門工資進(jìn)行統(tǒng)計(jì),然后再使用having子句對(duì)統(tǒng)計(jì)結(jié)果進(jìn)行篩選。

select deptno,sum(sal) from emp 
where deptno!='10' group by deptno
having sum(sal)>8000;

篩選結(jié)果如下:

DEPTNO SUM(SAL)
—— ———-
30 9400
20 10875

五、異同點(diǎn)

它們的相似之處就是定義搜索條件,不同之處是where子句為單個(gè)篩選而having子句與組有關(guān),而不是與單個(gè)的行有關(guān)。
最后:理解having子句和where子句最好的方法就是基礎(chǔ)select語句中的那些句子的處理次序:where子句只能接收from子句輸出的數(shù)據(jù),而having子句則可以接受來自group by,where或者from子句的輸入。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“SQL中where子句與having子句的區(qū)別有哪些”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

分享名稱:SQL中where子句與having子句的區(qū)別有哪些
標(biāo)題URL:http://www.aaarwkj.com/article8/gipgip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT品牌網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)網(wǎng)站建設(shè)、網(wǎng)站策劃、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
日本不卡视频二区三区| 欧美另类亚洲综合久青草| 青青草日韩欧美在线观看| 日韩精品 视频二区| 精品爆白浆一区二区三区| 色吊丝日韩在线观看| 一二三日韩电影在线观看| 色欧美在线视频观看日韩| 亚洲欧美国产日韩另类| 日韩精品在线免费观看了| 亚洲人妻一区二区三区久久精品 | 久久精品亚洲夜色国产av| 欧美一区二区三区情色| 少妇人妻偷人精品系列| 日韩夫妻性生活免费视频| 日本高清免费中文字幕| 黄片视频免费在线观看播放| 高清大片免费看一区二区| 国产丝袜美女一区二区| 成人激情在线免费电影| 亚洲免费av第一区第二区| 国产伦奸在线播放免费| 91久久精品人妻一区二区| 国产精品人妻在线av| 日韩高清av一区二区| 亚洲国产日韩欧美综合久久| 成人欧美一区二区三区av| 97人妻人人澡人人添人人爽| 日韩不伦高清一区二区三区| 日本人妻久久中文字幕| 欧美日韩免费爱爱视频| 综合久久—本道中文字幕| 欧美国产日韩一区二区三区视频| 亚洲国产欧美在线91| 国产又黄又粗的视频| 日韩欧美中文字幕综合网| 午夜一区二区三区精品| 欧美日韩在线视频一区| 国产精品免费观看在线国产| 国产99热这里只有精品| 国产乱国产乱老熟女视频|