sql 數據庫 where和having的使用場景與區別


where和having的使用場景與區別

分享關於mysql中的where和having子句的區別,本文主要分享對象為剛剛接觸sql的新人,下面將結合實際案例分析:

下面以一個例子來具體的講解:

1. where和having都可以使用的場景

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

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

解釋:上面的having可以用的前提是我已經篩選出了addtime字段,在這種情況下和where的效果是等效的,但是如果我沒有select addtime就會報錯!!因為having是從前面篩選的字段再篩選,而where是從數據表中的字段直接進行的篩選的。

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

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

2) select phone,name from dw_users having addtime> 1500000000//報錯!!!因為前面並沒有篩選出addtime字段

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

查詢每種category_id商品的價格平均值,獲取平均價格大於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 //報錯!!因為from dw_goods 這張數據表里面沒有ag這個字段

注意:
where 后面要跟的是數據表里的存在的字段,如果我把ag換成avg(price)也是錯誤的!因為表里沒有該字段。
而having只是根據前面查詢出來的是什么就可以后面接什么(比如一些聚合函數這樣的“偽字段”)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM