数据库教程:MySQL高级查询之与Group By集合使用介绍分享

GROUP_CONCAT

mysql> SELECTstudent_name,
   ->     GROUP_CONCAT(test_score)
   ->     FROMstudent
   ->     GROUPBYstudent_name;

Or:

mysql> SELECTstudent_name,
   ->     GROUP_CONCAT(DISTINCTtest_score
   ->               ORDERBYtest_scoreDESCSEPARATOR”)
   ->     FROMstudent
   ->     GROUPBYstudent_name;

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

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

 2 WITHROLLUP

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

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

mysql> SELECTyear,SUM(profit)FROMsalesGROUPBYyearWITHROLLUP;

+——+————-+

|year|SUM(profit)|

+——+————-+

|2000|       4525|

|2001|       3010|

|NULL|       7535|

+——+————-+

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

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

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

mysql> SELECTyear,country,product,SUM(profit)

   -> FROMsales

   -> GROUPBYyear,country,product;

+——+———+————+————-+

|year|country|product   |SUM(profit)|

+——+———+————+————-+

|2000|Finland|Computer  |       1500|

|2000|Finland|Phone     |        100|

|2000|India  |Calculator|        150|

|2000|India  |Computer  |       1200|

|2000|USA    |Calculator|         75|

|2000|USA    |Computer  |       1500|

|2001|Finland|Phone     |         10|

|2001|USA    |Calculator|         50|

|2001|USA    |Computer  |       2700|

|2001|USA    |TV        |        250|

+——+———+————+————-+

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

mysql> SELECTyear,country,product,SUM(profit)

   -> FROMsales

   -> GROUPBYyear,country,productWITHROLLUP;

+——+———+————+————-+

|year|country|product   |SUM(profit)|

+——+———+————+————-+

|2000|Finland|Computer  |       1500|

|2000|Finland|Phone     |        100|

|2000|Finland|NULL      |       1600|

|2000|India  |Calculator|        150|

|2000|India  |Computer  |       1200|

|2000|India  |NULL      |       1350|

|2000|USA    |Calculator|         75|

|2000|USA    |Computer  |       1500|

|2000|USA    |NULL      |       1575|

|2000|NULL   |NULL      |       4525|

|2001|Finland|Phone     |         10|

|2001|Finland|NULL      |         10|

|2001|USA    |Calculator|         50|

|2001|USA    |Computer  |       2700|

|2001|USA    |TV        |        250|

|2001|USA    |NULL      |       3000|

|2001|NULL   |NULL      |       3010|

|NULL|NULL   |NULL      |       7535|

+——+———+————+————-+

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

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

您可能感兴趣的文章:解析mysql中:单表distinct、多表groupby查询去除重复记录mysql分组取每组前几条记录(排名)附groupby与orderby的研究mysql中groupby与having合用注意事项分享使用GROUPBY的时候如何统计记录条数COUNT(*)DISTINCT深入解析mysql中orderby与groupby的顺序问题关于MYSQL中每个用户取1条记录的三种写法(groupbyxxx)mysql筛选GROUPBY多个字段组合时的用法分享MySql版本问题sql_mode=only_full_group_by的完美解决方案详解SQL中GroupBy的用法一篇文章带你了解数据库中groupby的用法

标签: SQL

mysql技巧之select count的区别分析

用VirtualBox构建MySQL测试环境的笔记

上述就是数据库技术:MySQL高级查询之与Group By集合使用介绍分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

www.ctvol.com true Article 数据库教程:MySQL高级查询之与Group By集合使用介绍分享

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/910857.html

(0)
上一篇 2021年10月24日 下午4:46
下一篇 2021年10月24日 下午4:48

精彩推荐