1. 程式人生 > >正確理解MySQL中的where和having的區別(轉載)

正確理解MySQL中的where和having的區別(轉載)

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的區別(轉載)