1、----------------------where和having------------------------
2、where
where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚合函数,使用where条件显示特定的行。
3、having
having子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚合函数,使用having条件显示特定的组,也可以使用多个分组标准进行分组。
having子句被限制于已经在select语句中定义的列和聚合表达式上。通常,你需要通过在having子句中重复聚合函数表达式来引用聚合值,就如你在select语句中做的那样。
☆:having子句和where有相似之处:都是设定条件的语句。
但是二者也有区别:
在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行。而where子句在查询过程中执行优先级别优先于聚合语句。
简单来说:
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; //having子句查询过程执行优先级别低于聚合语句。
换句话说:
把上面的having换成where则会出错。统计分组数据时用到聚合语句。对分组数据再次判断时要用having。如果不用这些关系就不存在使用having。直接使用where就行了。
having就是用来弥补where在分组数据判断时的不足。因为where执行优先级别要快于聚合函数。