分享關(guān)于mysql中的where和having子句的區(qū)別,本文主要分享對(duì)象為剛剛接觸sql的新人,下面將結(jié)合實(shí)際案例分析:
下面以一個(gè)例子來(lái)具體的講解:
1. where和having都可以使用的場(chǎng)景
1)select addtime,name from dw_users where addtime> 1500000000
2)select addtime,name from dw_users having addtime> 1500000000
解釋?zhuān)荷厦娴膆aving可以用的前提是我已經(jīng)篩選出了addtime字段,在這種情況下和where的效果是等效的,但是如果我沒(méi)有select addtime就會(huì)報(bào)錯(cuò)!!因?yàn)閔aving是從前面篩選的字段再篩選,而where是從數(shù)據(jù)表中的字段直接進(jìn)行的篩選的。
2. 只可以用where,不可以用having的情況
1) select addtime,name from dw_users where addtime> 1500000000
2) select phone,name from dw_users having addtime> 1500000000?//報(bào)錯(cuò)!??!因?yàn)榍懊娌](méi)有篩選出addtime字段
3. 只可以用having,不可以用where情況
查詢(xún)每種category_id商品的價(jià)格平均值,獲取平均價(jià)格大于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 //報(bào)錯(cuò)??!因?yàn)閒rom dw_goods 這張數(shù)據(jù)表里面沒(méi)有ag這個(gè)字段
注意:
where 后面要跟的是數(shù)據(jù)表里的存在的字段,如果我把a(bǔ)g換成avg(price)也是錯(cuò)誤的!因?yàn)楸砝餂](méi)有該字段。
而having只是根據(jù)前面查詢(xún)出來(lái)的是什么就可以后面接什么(比如一些聚合函數(shù)這樣的“偽字段”)。