MYSQL基础
1.having和group by的区别?
1.having:用于对where和group by查询出来的分组经行过滤,查出满足条件的分组结果。它是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作。
2.group by:对select查询出来的结果集按照某个字段或者表达式进行分组,获得一组组的集合,然后从每组中取出一个指定字段或者表达式的值。 在说group by的时候,我们还需要了解聚合函数,聚合函数是SQL语言中一种特殊的函数。
关于聚合索引、group by与having的使用:https://blog.csdn.net/intmainhhh/article/details/80777582
having进行条件指定讲究有点多:having后面跟
1.聚合函数,比如最大值,最小值,平均值,等等
2.如果没有聚合函数则必须是存在于select中的某个字段
扩展资料:
group by,where,having 是数据库查询中最常用的几个关键字。在工作中,时常用到,当一个语句中同时含有where、group by 、having及聚集函数时,执行顺序如下:
执行where子句查找符合条件的数据;使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。需要注意的是,having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle。
---恢复内容结束---