以前在學校裏學習過SQLserver數據庫,發現學習的都是皮毛,今天以正確的姿態談一下MySQL中where和having的區別。
誤區:不要錯誤的認爲having和group by 必須配合使用。
下面以一個例子來具體的講解:
1. where和having都可以使用的場景
select goods_price,goods_name from sw_goods where goods_price > 100
- 1
select goods_price,goods_name from sw_goods having goods_price > 100
- 1
解釋:上面的having可以用的前提是我已經篩選出了goods_price字段,在這種情況下和where的效果是等效的,但是如果我沒有select goods_price 就會報錯!!因爲having是從前篩選的字段再篩選,而where是從數據表中的字段直接進行的篩選的。
2. 只可以用where,不可以用having的情況
select goods_name,goods_number from sw_goods where goods_price > 100
- 1
select goods_name,goods_number from sw_goods having goods_price > 100 //報錯!!!因爲前面並沒有篩選出goods_price 字段
- 1
3. 只可以用having,不可以用where情況
查詢每種goods_category_id商品的價格平均值,獲取平均價格大於1000元的商品信息
select goods_category_id , avg(goods_price) as ag from sw_goods group by goods_category having ag > 1000
- 1
select goods_category_id , avg(goods_price) as ag from sw_goods where ag>1000 group by goods_category //報錯!!因爲from sw_goods 這張數據表裏面沒有ag這個字段
- 1
注意:where 後面要跟的是數據表裏的字段,如果我把ag換成avg(goods_price)也是錯誤的!因爲表裏沒有該字段。而having只是根據前面查詢出來的是什麼就可以後面接什麼。