一代菜鸡斗胆投报阿里,果真迎来了圣枪洗礼!
Hr:说一下where 和 having 的区别吧。
菜鸡(我):我…有点不记得了,太久没用了,我只记得having 要 和 group by (分组)搭配。
Hr:…(沉默),,哦,那你还有什么问题想问吗?
男默女泪,菜不成声。
礼毕!请呐喊!请彷徨!
啊!!!啊!!!啊!!!
A man can be destroyed but not defeated!
———————————————————————————————————————————
Where 和 Having 的 一点区别
首先他们两个都是做条件筛选的,而筛选的字段有所不同!
此话怎讲?
首先 where 筛选的字段是 表中 对应的字段,这里以一个简单的 goods(货物)表 为例
where:
可见,select 后面没有写 id ,where 也能根据 id 查。但是having 就不行了
having:
在select 后加上 id 就可以了,因为having 是 根据select 后面跟的属性进行筛选的
目测where比较简便,但同样局限性大。
比如:所依据的字段不是表中带有的,avg(price) 等。
select id avg(price) where avg(price) > 10 就会报错
而
select id avg(price) having avg(price) > 10 就不会报错
当然这个例子不好,看不出这两个sql语句到底有什么实际意义,,
但是可以说明MySql中where和having的一点用法上的区别
最后说明一下,having不是天生用来和group by 搭配使用的,
而是大多数情况下他们两个一起用会比较容易解决问题。
where也可以和group by 一同使用,
只不过where 要放在 group by 的前面 而 having是放在后面。(单纯从语法上讲)
努力的道路依旧长,风景还有很多要赏.