正確理解MySQL中的where和having的區別(轉載)
阿新 • • 發佈:2018-04-16
pri keyword 均值 VG pan group 解釋 having sele
下面以一個例子來具體的講解:
1. where和having都可以使用的場景
select goods_price,goods_name from sw_goods where goods_price > 100
select goods_price,goods_name from sw_goods having goods_price > 100
解釋:上面的having可以用的前提是我已經篩選出了goods_price字段,在這種情況下和where的效果是等效的,但是如果我沒有select goods_price 就會報錯!!因為having是從前篩選的字段再篩選,而where是從數據表中的字段直接進行的篩選的。
2. 只可以用where,不可以用having的情況
select goods_name,goods_number from sw_goods where goods_price > 100
select goods_name,goods_number from sw_goods having goods_price > 100 //報錯!!!因為前面並沒有篩選出goods_price 字段
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
select goods_category_id , avg(goods_price) as ag from sw_goods where ag>1000 group by goods_category //報錯!!因為from sw_goods 這張數據表裏面沒有ag這個字段
註意:where 後面要跟的是數據表裏的字段,如果我把ag換成avg(goods_price)也是錯誤的!因為表裏沒有該字段。而having只是根據前面查詢出來的是什麽就可以後面接什麽。
正確理解MySQL中的where和having的區別(轉載)