`

Mysql 的按时间段分组查询

阅读更多
   当我们有一个datetime类型的字段希望,能够按照时间段分组,显示统计信息,那么,下面的mysql语句将会用到:

   首先,我们有如下表结构

mysql> show columns from alarms;




执行语句如下:

select count(*) , floor(event_time/1500)*1500 as gt from alarms group by gt order by gt;


结果显示如下:




和分组相关的信息

1 GROUP_CONCAT
mysql> SELECT student_name,
     GROUP_CONCAT(test_score)
     FROM student
     GROUP BY student_name;
Or:
mysql> SELECT student_name,
     GROUP_CONCAT(DISTINCT test_score
     ORDER BY test_score DESC SEPARATOR ' ')
     FROM student
     GROUP BY student_name;


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

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

2 WITH ROLLUP

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

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

mysql> SELECT year, SUM(profit) FROM sales GROUP BY year WITH ROLLUP;

+------+-------------+
| year | SUM(profit) |
+------+-------------+
| 2000 |        4525 |
| 2001 |        3010 |
| NULL |        7535 |
+------+-------------+

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

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

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

mysql> SELECT year, country, product, SUM(profit)
         FROM sales
         GROUP BY year, 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> SELECT year, country, product, SUM(profit)
         FROM sales
         GROUP BY year, country, product WITH ROLLUP;


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

LIMIT可用来限制返回客户端的行数。LIMIT 用在 ROLLUP后面, 因此这个限制 会取消被ROLLUP添加的行
  • 大小: 20.9 KB
  • 大小: 5 KB
分享到:
评论
1 楼 hot66hot 2011-11-28  
好文章.

相关推荐

    MySQL DQL - 分组查询.md

    - **性能监控**:按时间段分组,计算每个时间段内的平均响应时间。 #### 小结 通过使用`GROUP BY`语句结合聚合函数,可以在MySQL中高效地对数据进行分组和统计。这对于业务分析、报表生成以及日常的数据处理都极为...

    sqlserver/mysql按天、按小时、按分钟统计连续时间段数据【推荐】

    - 这些生成的连续时间段可以作为`GROUP BY`子句中的字段,以便按时间段对数据进行分组统计。例如,对于按天统计交易笔数,可以将生成的日期与交易数据的日期字段进行匹配,然后计算每天的交易次数。 4. **与业务...

    mysql 统计一天24小时数据默认补0SQL

    本文将通过具体的MySQL查询语句,详细介绍如何实现一天24小时的数据统计,并对缺失数据进行默认补0的操作。 #### 核心概念与背景 1. **左连接(LEFT JOIN)**:在两个表中,基于共同列进行连接操作时,左连接会...

    MYSQL每隔10分钟进行分组统计的实现方法

    在数据库领域,进行数据统计分析是常见的需求,尤其是在实时监控、业务分析等场景中,需要对数据按时间段进行分组统计。本文将详细介绍如何使用MySQL数据库每隔一定时间(例如每10分钟)对数据进行分组统计的实现...

    国家开放大学 MySQL数据库应用 实验训练2:数据查询操作

    同样,查询此汽车用品网上商城会员的创建时间段,也需要使用 DISTINCT 语句来去重。 ORDER BY 在实验 2.4 中,我们学习了如何使用 ORDER BY 语句来排序结果。例如,查询类别 ID 为 1 的所有商品,结果按照商品 ID ...

    mysql 获取规定时间段内的统计数据

    在MySQL数据库中,获取规定时间段内的统计数据是一项常见的需求,尤其对于数据分析和业务监控至关重要。这里我们将探讨如何使用MySQL的时间函数来实现这样的统计。 首先,我们要理解`DATE_FORMAT()`函数的作用。这...

    mysql 查询行列转换

    例如,将某个时间序列的数据从行转换为列,可以先通过 GROUP BY 时间段生成子查询,然后将这些子查询的结果联接起来。 3. **GROUP BY 和聚合函数**: 当需要对特定列进行汇总统计时,可以结合 GROUP BY 和聚合函数...

    详解mysql 获取某个时间段每一天、每一个小时的统计数据

    在MySQL中,获取某个时间段内每一天或每一个小时的统计数据是一项常见的数据分析任务,这对于日志分析、业务监控等场景尤其有用。以下将详细讲解如何实现这一功能。 首先,我们来看如何获取每一天的统计数据。假设...

    MYSQL

    8 MySQL 教程 8.1 联接和断开服务器 8.2 输入查询 8.3 常用查询的例子 8.3.1 列的最大值 8.3.2 拥有某个列的最大值的行 8.3.3 列的最大值:按组:只有值 8.3.4 拥有某个字段的组间...

    MYSQL时间处理(全)

    3. **长时间段内的统计:** - 统计过去一个月内`t_asset_check_result_bak`表中的记录数量: ```sql SELECT DATE_FORMAT(model.ENTER_DATE, '%Y-%m-%d') label, COUNT(1) value FROM t_asset_check_result_...

    MySQL中文参考手册.chm

    8 MySQL 教程 8.1 联接和断开服务器 8.2 输入查询 8.3 常用查询的例子 8.3.1 列的最大值 8.3.2 拥有某个列的最大值的行 8.3.3 列的最大值:按组:只有值 8.3.4 拥有某个字段的...

    MySQL中文参考手册

    + 7.3.6 日期和时间类型 # 7.3.6.1 问题和日期类型 # 7.3.6.2 DATETIME,DATE和TIMESTAMP类型 # 7.3.6.3 TIME类型 # 7.3.6.4 YEAR类型 + 7.3.7 字符串类型 # 7.3.7.1 CHAR和VARCHAR类型 # 7.3.7.2 BLOB和TEXT...

    Mysql数据库(6天)

    - `GROUP BY`:分组查询。 - **DCL数据控制语言**:用于管理权限和事务。 - `GRANT`:授予用户权限。 - `REVOKE`:收回用户权限。 #### 四、Mysql高级特性 - **存储引擎**:MySQL支持多种存储引擎,其中最常用的...

    Mysql练习7:按季度统计本年发布的房屋出租数量.zip

    这涉及到对时间数据的操作,子查询的运用以及数据库查询优化。在实际的房地产管理或数据分析场景中,这样的统计信息对于理解市场动态、规划营销策略或评估业务表现至关重要。 首先,我们需要一个包含房屋出租信息的...

    mysql数据操作和mysql授权操作

    例如,以下查询将按年龄分组员工,然后找出每个年龄段的最大年龄: ```sql SELECT age, MAX(salary) FROM employees GROUP BY age HAVING MAX(salary) > 50000 ORDER BY age; ``` 正则表达式可以在`LIKE`或`...

    MYSQL 通过分区(Partition)提升MySQL性能

    例如,如果需要清理某个特定时间段的数据,可以直接删除对应的分区,而不会影响其他数据。这使得数据备份、恢复以及清理等工作变得更加简单高效。 综上所述,通过合理利用MySQL中的分区技术,不仅可以显著提高查询...

    mysql经典性能查询SQL

    13. **批量生成分表SQL**:对于分表操作,这个查询可以自动生成按ID分组的SQL,便于数据统计。 14. **Mysqldump备份参数**:提供的命令展示了如何使用`mysqldump`进行备份,包括指定用户、密码、套接字路径等。 ...

    mysql参考手册中文版

    MySQL支持多种数据类型,包括数值类型(如INT、DECIMAL)、字符串类型(如VARCHAR、TEXT)、日期和时间类型(如DATE、TIMESTAMP)以及二进制类型(如BLOB)。 五、表的操作 1. 创建表:CREATE TABLE语句定义表结构...

Global site tag (gtag.js) - Google Analytics