MySQL高级查询之与GroupBy集合使用介绍
1 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服务启动失败:调查与解决(mysql服务无法启动)
- MySQL列排序规则实战精讲(mysql列排序规则)
- MySQL下载指南:从零开始(mysql下载步骤)
- MySQL中的数值转换:简单而有效(mysql数值转换)
- MySQL数据库:快速上手指南(mysql数据库怎么使用)
- 如何使用Eclipse连接MySQL数据库(eclipse怎么连接mysql数据库)
- 配置MySQL配置指南:简单使用.cnf文件(mysql.cnf)
- MySQL中使用无符号INT类型的优势(mysql无符号int)
- 的安装Mac下MySQL安装指南(mac中mysql)
- MySQL表变量的使用方法(mysql表变量)
- MySQL 事务处理:使用临时表(mysql事务临时表)
- MySQL建表权限:赋予数据库管理员完全控制(mysql建表权限)
- 升级MySQL: 使用Yum轻松实现(yum升级mysql)
- 简化MySQL数据库操作:使用MySQL链接工具(链接mysql工具)
- 用户MySQL用户如何快速下载软件(下载mysql)
- MySQL:如何使用求平均数函数?(mysql求平均数)
- MySQL如何加入函数及使用方法(mysql加函数)
- 通过CMD使用SSH连接远程MySQL数据库(cmd连接远程mysql)
- MySQL连接时间怎么配置?(mysql配置连接时间)
- Linux下快速启动MySQL服务器的命令(linux启动mysql命令)
- MySQL中事务并发控制打开数量优化(mysql中事物打开数量)
- MySQL中的非唯一与唯一约束(mysql中不唯一的)
- MySQL中使用ASCII编码的方法(mysql中上ascii)
- C 语言使用 MySQL 数据库连接池技术解决方案(c 使用mysql链接池)
- BAT实习生解析MySQL面试题(bat和mysql面试题)
- 一键使用 MySQL 57 版本,免受安装之苦(5.7mysql免安装)
- Windows下Cmd如何使用MySQL查询数据库(cmd如何运用mysql)
- 在CMD中使用命令连接MySQL数据库(cmd命令打开mysql)
- MySQL下拉表的使用方法详解(mysql下拉表怎么用)