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只是根據前面查詢出來的是什么就可以后面接什么(比如一些聚合函數這樣的“偽字段”)。