当一个查询语句同时出现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
    _

    粗浅的理解的话