mysql中having语句与where语句的用法与区别

页面导航:首页 > 数据库 > Mysql > mysql中having语句与where语句的用法与区别

mysql中having语句与where语句的用法与区别

来源: 作者: 时间:2016-02-17 10:07 【

mysql中having语句与where语句的用法与区别我们在写sql语句的时候,经常会使用where语句,很少会用到having,其实在mysql中having子句也是设定条件的语句与where有相似之处但也有区别。having子句在
中having语句与where语句的用法与区别
 
我们在写sql语句的时候,经常会使用where语句,很少会用到having,其实在mysql中having子句也是设定条件的语句与where有相似之处但也有区别。having子句在查询过程中慢于聚合语句(sum,min,max,avg,count).而where子句在查询过程中则快于聚合语句(sum,min,max,avg,count)。  
 
简单说来:  
 
where子句:  
select sum(num) as rmb from order where id>10  
//先查询出id大于10的记录才能进行聚合语句  

having子句:  
select reportsto as manager, count(*) as reports from employees  
group by reportsto having count(*) > 4  

 

 
以test库为例.having条件表达示为聚合语句。肯定的说having子句查询过程慢于聚合语句。  
再换句说话说把上面的having换成where则会出错。统计分组数据时用到聚合语句。  
 
对分组数据再次判断时要用having。如果不用这些关系就不存在使用having。直接使用where就行了。  
having就是来弥补where在分组数据判断时的不足。因为where要快于聚合语句。
 
Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<