mysql中 having 和 where 的区别

区别1

where是从数据表中的字段直接进行的筛选的。

having是从 前面筛选的字段再筛选

eg:  select goods_price,goods_name from goods having  goods_price > 100

                     等价于  

       select goods_price,goods_name from goods where goods_price > 100

 

select goods_name,goods_number from goods having  goods_price > 100   

// 报错!!!因为前面并没有筛选出 goods_price 字段

 

区别2

having子句中可以使用字段别名,而where不能使用

 

区别3

having能够使用统计函数,先分组,再判断(having),但是where不能使用

 

 

用的地方不一样

   where可以用于select、update、delete和insert into values(select * from table where ..)语句中。

   having只能用于select语句中

执行的顺序不一样

   where的搜索条件是在执行语句进行分组之前应用

   having的搜索条件是在分组条件后执行的

   即如果where和having一起用时,where会先执行,having后执行

子句有区别

   where子句中的条件表达式having都可以跟,而having子句中的有些表达式where不可以跟;having子句可以用集合函数(sum、count、avg、max和min),而where子句不可以。

总结

 1.WHERE 子句用来筛选 FROM 子句中指定的操作所产生的行。
2.GROUP BY 子句用来分组 WHERE 子句的输出。
3.HAVING 子句用来从分组的结果中筛选行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值