在OracleSQL中进行时间切片

在OracleSQL中进行时间切片,第1张

概述我有一个包含代表工作单元的行的大型Oracle表,除了其他元数据外还有开始时间和结束时间的列. 我需要根据这些数据生成使用图,给出一些任意的过滤标准和报告时间段.例如,向我展示上周二上午7点开始的24小时内所有Alice工作的图表.每个DB行将在图中垂直堆叠. 我可以通过查询所有可能相关的行,将每个行分成1分钟的时间段并绘制结果图表,以高级语言执行此 *** 作.但是有没有一种有效的方法来在SQL中进行切 我有一个包含代表工作单元的行的大型Oracle表,除了其他元数据外还有开始时间和结束时间的列.

我需要根据这些数据生成使用图,给出一些任意的过滤标准和报告时间段.例如,向我展示上周二上午7点开始的24小时内所有Alice工作的图表.每个DB行将在图中垂直堆叠.

我可以通过查询所有可能相关的行,将每个行分成1分钟的时间段并绘制结果图表,以高级语言执行此 *** 作.但是有没有一种有效的方法来在sql中进行切片?或者是否有现成的Oracle技术可以做到这一点?

谢谢!

解决方法 在获取数据方面,您可以使用“分组依据”和“ truncate”将数据分成1分钟的间隔.例如:

SELECT user_name,truncate(event_time,'YYYYMMDD HH24MI'),count(*)FROM job_tableWHERE event_time > TO_DATE( some start date time)AND user_name IN ( List of users to query )GROUP BY user_name,'YYYYMMDD HH24MI')

这将给你如下的结果(假设alice有20行,在8.00和8.01之间,40行在8.01和8.02之间):

Alice  2008-12-16 08:00   20Alice  2008-12-16 08:01   40
总结

以上是内存溢出为你收集整理的在Oracle / SQL中进行时间切片全部内容,希望文章能够帮你解决在Oracle / SQL中进行时间切片所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1165790.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存