关于GROUP BY的使用注意事项

    作者:课课家教育更新于: 2019-04-09 13:39:58

      大家都知道GROUP BY,但是大家知道GROUP BY后面可以带哪些函数吗?今天给大家介绍下GROUP BY后面可以带的函数。

    三种mysql高级查询技巧_数据库_mysql函数_课课家

      1GROUP_CONCAT

      在MySQL中,你可以获取表达式组合的连接值。你可以使用DISTINCT删去重复值。假若你希望多结果值进行排序,则应该使用ORDERBY子句。若要按相反顺序排列,将DESC(递减)关键词添加到你要用ORDERBY子句进行排序的列名称中。默认顺序为升序;可使用ASC将其明确指定。SEPARATOR后面跟随应该被插入结果的值中间的字符串值。默认为逗号(‘,’)。通过指定SEPARATOR'',你可以删除所有分隔符。

      PS:就是可以在一个语句中得到GROUPBY被聚合的项的每个子值的一个组合的字符串

      2WITH  ROLLUP

      GROUPBY子句允许一个将额外行添加到简略输出端WITHROLLUP修饰符。这些行代表高层(或高聚集)简略操作。ROLLUP因而允许你在多层分析的角度回答有关问询的问题

      或者你可以使用ROLLUP,它能用一个问询提供双层分析。将一个WITHROLLUP修饰符添加到GROUPBY语句,使询问产生另一行结果,该行显示了所有年份的总价值:

      总计高聚集行被年份列中的NULL值标出。

      当有多重GROUPBY列时,ROLLUP产生的效果更加复杂。这时,每次在除了最后一个分类列之外的任何列出现一个“break”(值的改变),则问讯会产生一个高聚集累计行。

      例如,在没有ROLLUP的情况下,一个以年、国家和产品为基础的关于sales表的一览表可能如下所示:

      表示总值的输出结果仅位于年/国家/产品的分析级别。当添加了ROLLUP后,问询会产生一些额外的行:

      

      当你使用ROLLUP时,你不能同时使用ORDERBY子句进行结果排序。换言之,ROLLUP和ORDERBY是互相排斥的。然而,你仍可以对排序进行一些控制。在MySQL中,GROUPBY可以对结果进行排序,而且你可以在GROUPBY列表指定的列中使用明确的ASC和DESC关键词,从而对个别列进行排序。(不论如何排序被ROLLUP添加的较高级别的总计行仍出现在它们被计算出的行后面)。

      LIMIT可用来限制返回客户端的行数。LIMIT用在ROLLUP后面,因此这个限制会取消被ROLLUP添加的行。

      学习了GROUPBY后面可以带的函数的知识,大家以后在工作中就要多加小心,避免乱用造成损失。

课课家教育

未登录