sql中where和having的使用場(chǎng)景與區(qū)別(必看,很重要?。?/h2>

分享關(guān)于mysql中的where和having子句的區(qū)別,本文主要分享對(duì)象為剛剛接觸sql的新人,下面將結(jié)合實(shí)際案例分析:

下面以一個(gè)例子來(lái)具體的講解:

1. where和having都可以使用的場(chǎng)景

1)select addtime,name from dw_users where addtime> 1500000000

2)select addtime,name from dw_users having addtime> 1500000000

解釋?zhuān)荷厦娴膆aving可以用前提是我已經(jīng)篩選出了addtime字段,在這種情況下和where的效果是等效的,但是如果我沒(méi)有select addtime就會(huì)報(bào)錯(cuò)!!因?yàn)閔aving是從前面篩選的字段再篩選,而where是從數(shù)據(jù)表中的字段直接進(jìn)行的篩選的。


2. 只可以用where,不可以用having的情況

1) select addtime,name from dw_users where addtime> 1500000000

2) select phone,name from dw_users having addtime> 1500000000?//報(bào)錯(cuò)!??!因?yàn)榍懊娌](méi)有篩選出addtime字段

3. 只可以用having,不可以用where情況

查詢(xún)每種category_id商品的價(jià)格平均值,獲取平均價(jià)格大于100元的商品信息

1)select category_id , avg(price) as ag from dw_goods group by goods_category having ag > 100

2)select category_id , avg(price) as ag from dw_goods where ag>100 group by goods_category //報(bào)錯(cuò)??!因?yàn)閒rom dw_goods 這張數(shù)據(jù)表里面沒(méi)有ag這個(gè)字段

注意:

where 后面要跟的是數(shù)據(jù)表里的存在的字段,如果我把a(bǔ)g換成avg(price)也是錯(cuò)誤的!因?yàn)楸砝餂](méi)有該字段。

而having只是根據(jù)前面查詢(xún)出來(lái)的是什么就可以后面接什么(比如一些聚合函數(shù)這樣的偽字段”)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容