当一个查询语句同时出现where , group by , having , order by 的时候,执行顺序和编写顺序。
使用count(列名) 当某列出现null值的时候, count(*)仍然会计算,但是count(列名)不会。
当一个查询语句同时出现where、group by 、 having、order by的时候,执行顺序和编写顺序是:
1、执行where xx 对全表数据做筛选, 返回第一个结果集。
2、针对第一个结果集使用group by 分组, 返回第二个结果集。
3、针对第二个结果集中的每1组数据执行select xx , 有几组就执行几次,返回第3个结果集
4、针对第三个结果集执行having xx进行筛选,返回第4个结果集。
5、针对第四个结果集排序
——————————————————
Group By 和 Having 、where 、Order by 这些关键字是按照如下顺序进行执行的:
Where、 group by 、Having 、Order by
_
粗浅的理解的话