计算不同时间范围内项目的平均分钟数

Posted

技术标签:

【中文标题】计算不同时间范围内项目的平均分钟数【英文标题】:Calculating average minutes for items within different time frames 【发布时间】:2014-10-29 18:25:27 【问题描述】:

我有一个数据集需要分成两个子集。每个子集必须仅包括特定时间范围内的项目。然后,我需要取 MAX(上次编辑时间)-MIN(项目添加时间)并除以子集中的项目数量。因此,我的目标是计算在两个时间范围内处理所有项目所需的平均时间。看图!

我试过了,但它似乎不起作用——结果不正确;该查询在 WHERE 子句中概述的整个时间段内生成 MIN 和 MAX 的结果(因此多天的时间段会极大地破坏结果)。

SELECT 
  CASE
    WHEN TO_CHAR(ADDED, 'HH24') BETWEEN 09 AND 11
    THEN TRUNC(((MAX(MODIFIED) - MIN(ADDED))*24*60)/COUNT(TRANSACTIONS))
    ELSE 0
  END 
    +
  CASE
    WHEN TO_CHAR(ADDED, 'HH24') BETWEEN 15 AND 19
    THEN TRUNC(((MAX(MODIFIED) - MIN(ADDED))*24*60)/COUNT(TRANSACTIONS))
    ELSE 0
  END AS subsets_average
FROM TABLE

【问题讨论】:

【参考方案1】:

我明白你在做什么。 case 语句位于错误的位置。您需要聚合函数内部的条件:

SELECT TRUNC(((MAX(MODIFIED END)-
               MIN(ADDED ))*24*60)/COUNT(TRANSACTIONS) as grand_average,
       TRUNC(((MAX(TO_CHAR(ADDED, 'HH24') BETWEEN 09 AND 11 THEN MODIFIED END)-
               MIN(TO_CHAR(ADDED, 'HH24') BETWEEN 09 AND 11 THEN ADDED END))*24*60)/COUNT(TRANSACTIONS)
             ) +
       TRUNC(((MAX(TO_CHAR(ADDED, 'HH24') BETWEEN 15 AND 19 THEN MODIFIED END)-
               MIN(TO_CHAR(ADDED, 'HH24') BETWEEN 15 AND 19 THEN ADDED END))*24*60)/COUNT(TRANSACTIONS) AS subsets_average
FROM TABLE

【讨论】:

以上是关于计算不同时间范围内项目的平均分钟数的主要内容,如果未能解决你的问题,请参考以下文章

如何计算熊猫数据框中子组内项目的成对出现?

按价格排序列表,由列表内项目的子字符串计算#

ENVI计算不同轨道号范围中的平均高程

Git:在日期范围内更改的平均行数和总行数

使用 Azure Monitor Metrics 获取平均每日计算分钟数

计算和平均范围