您现在的位置是:网站首页> 编程资料编程资料
group by 按某一时间段分组统计并查询(推荐)_MsSql_
2023-05-26
367人已围观
简介 group by 按某一时间段分组统计并查询(推荐)_MsSql_
工作中要求对日志表中的时间戳字段进行分组。分组的条件是,相隔 1分钟间隔的被分到一组。
数据库表是这样的

SELECT COUNT(log_id) AS u_count FROM logdb.`log` GROUP BY TIMESTAMP-TIMESTAMP%(1*60)
其中timestamp 是数据库时间字段。 括号中的1 是间隔时间,1分钟。 如果是1小时,就写60,如果是30s 就写0.5
结果

那被分组的id 如何解决呢?分完组我们还需要 哪些记录被分到哪些组了。
我们可以这么做。
SELECT COUNT(log_id) AS u_count ,GROUP_CONCAT(DISTINCT log_id ORDER BY log_id DESC ) AS ids FROM logdb.`log` GROUP BY TIMESTAMP-TIMESTAMP%(0.5*60)
GROUP_CONCAT(DISTINCT log_id ORDER BY log_id DESC )
这里默认使用 , 分割 将 log_id穿成字符串,并且这些id是不重复,且排序递降。

到此这篇关于group by 按某一时间段分组统计并查询的文章就介绍到这了,更多相关group by分组统计内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- 详解安装sql2012出现错误could not open key...解决办法_MsSql_
- SQL SERVER迁移之更换磁盘文件夹的完整步骤_MsSql_
- 详解GaussDB(DWS) explain分布式执行计划的示例_MsSql_
- 解决sql server保存对象字符串转换成uniqueidentifier失败的问题_MsSql_
- SQL server 自增ID--序号自动增加的字段操作_MsSql_
- SQL Server中identity(自增)的用法详解_MsSql_
- SqlServer生成连续数字根据指定的数字操作_MsSql_
- Microsoft SQL Server数据库各版本下载地址集合_MsSql_
- Zabbix监控SQL Server服务状态的方法详解_MsSql_
- SQL Server 开窗函数 Over()代替游标的使用详解_MsSql_
