需求:统计当天的访问量,每五分钟采集一次

表结构中有日期字段,类型TIMESTAMP

如果,统计是采用每秒/分钟/小时/天/周/月/年,都非常容易实现,只要to_char日期字段然后group by分组即可

但是:如果是X秒/分钟/小时/天/周/月/年 and X>1,就需要变通实现,方法如下:

方案一:临时表/临时存储

统计每5分钟的访问量,存入临时表或者临时存储(比如excel)

循环当天整个时间段

然后对临时表/临时存储的数据做排序

方案二:伪列的SQL查询(数据量小于<1亿数据量,且时间列做索引)

分析:5分钟一次,那就对每条记录做个伪列,每5分钟的数据都是一个标识。

比如:创建时间=201604061200 -至- 2016040612,这五分钟统一标识为2016040612

   创建时间=2016040612 -至- 2016040612,这五分钟统一标识为2016040612

实现起来非常方便:

a. 取出创建时间的分钟参数:to_char(t.create_time,'mi'),都是两位:比如01分,07分,13分,19分....

只判断第二位,如果第二位<5,统一让分钟的第二位=0,否则(第二位>=5)统一让分钟的第二位=5

而分钟的第一位不变

比如01分、04分统一标识为00分,05、06、09分统一标识为05分

切割字符串使用substr函数

判断使用case when

拼接使用||

b.取出创建时间的年月日小时参数,拼装上第一步的特殊分钟参数

一个伪列就这么诞生了

关键SQL如下:

case when substr(to_char(t.create_time,'mi'),2,1)<5 then to_char(t.create_time,'yyyymmddhh24')||substr(to_char(t.create_time,'mi'),1,1)||0
else to_char(t.create_time,'yyyymmddhh24')||substr(to_char(t.create_time,'mi'),1,1)||5 end as newTime

上一个完整的sql

select count(tmp.id) totalNum,tmp.newTime
from(
select t.id,t.latest_status, -- ID,状态
to_char(t.create_time,'yyyymmddhh24mi') oldTime, -- 原来的时间
case when substr(to_char(t.create_time,'mi'),2,1)<5 then to_char(t.create_time,'yyyymmddhh24')||substr(to_char(t.create_time,'mi'),1,1)||0
else to_char(t.create_time,'yyyymmddhh24')||substr(to_char(t.create_time,'mi'),1,1)||5 end as newTime -- 时间段伪列
from acquire_order t
where t.create_time>=to_date('20160406000000','yyyymmddhh24miss')
order by t.create_time asc
) tmp
group by tmp.newTime
order by totalNum desc

  

最新文章

  1. BZOJ 4581: [Usaco2016 Open]Field Reduction
  2. MySQL源码分析以及目录结构 2
  3. UESTC 884 方老师的专题讲座 --数位DP
  4. 洛谷P2015 二叉苹果树
  5. rsa加密--选择padding模式需要注意的问题。。。
  6. 有趣 GIF 动图集 - 仿佛每张小动图都诉说了一个小笑话或者小故事
  7. 《MFC游戏开发》笔记七 游戏特效的实现(一):背景滚动
  8. JAVA深复制(深克隆)与浅复制(浅克隆)
  9. 【HDU 4898】 The Revenge of the Princess’ Knight (后缀数组+二分+贪心+...)
  10. mkimage使用详解
  11. [Java] JavaMail 查询邮件
  12. Linux ulimit 系统资源控制
  13. Django 反向生成 从数据库生成Model
  14. Javascript高级程序设计——Javascript简史+使用Javascript
  15. 走近 Python (类比 JS)
  16. PHP能引起安全的函数
  17. (三十一)java多线程二
  18. sql注入--双查询报错注入原理探索
  19. 如何程序化的构造Hibernate配置 // How to initialize Hibernate programmably
  20. How to convert Word table into Excel using OpenXML

热门文章

  1. c++中代理类的学习
  2. wget访问tomcat管理界面
  3. xubuntu 安装一款漂亮的图标
  4. js实现的省市县三级联动的最新源码
  5. 网页设计和制作,数学,access 2010
  6. springboot2.x如何添加事务
  7. 位运算(2)——Number of 1 Bits
  8. html中的兼容 &amp; 如何对网站的文件和资源进行优化
  9. 用户管理的设计--3.jquery的ajax实现二级联动
  10. April 15 2017 Week 15 Saturday