正確理解where和having的使用

以前在學校裏學習過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只是根據前面查詢出來的是什麼就可以後面接什麼。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章