每组 SQL Server 前 n 个的平均值

Eri*_*ill 2 group-by average sql-server-2008 top-n

我正在研究寻找平均处理时间的问题。我试图通过仅对最好的 80% 数据进行平均来消除异常数据。

我正在努力尝试调整现有的每组前 N 个解决方案来执行每组的平均。使用 SQL Server 2008。

以下是该表的示例:

    OpID  |  ProcessMin  |  Datestamp
    2     |  234         |  2012-01-26 09:07:29.000
    2     |  222         |  2012-01-26 10:04:22.000
    3     |  127         |  2012-01-26 11:09:51.000
    3     |  134         |  2012-01-26 05:02:11.000
    3     |  566         |  2012-01-26 05:27:31.000
    4     |  234         |  2012-01-26 04:08:41.000
Run Code Online (Sandbox Code Playgroud)

我希望它为每个OpID取 ProcessMin 的最低 80% ,并取该数组的平均值。任何帮助,将不胜感激!

* 更新 *

给出下表:

OpID  ProcessMin   Datestamp
602   33           46:54.0
602   36           38:59.0
602   37           18:45.0
602   39           22:01.0
602   41           36:43.0
602   42           33:00.0
602   49           03:48.0
602   51           22:08.0
602   69           39:15.0
602   105          59:56.0
603   13           34:07.0
603   18           07:17.0
603   31           57:07.0
603   39           01:52.0
603   39           01:02.0
603   40           40:10.0
603   46           22:56.0
603   47           11:03.0
603   48           40:13.0
603   56           25:01.0
Run Code Online (Sandbox Code Playgroud)

我期望这个输出:

OptID   ProcessMin
602     41
603     34.125
Run Code Online (Sandbox Code Playgroud)

请注意,由于每个 OpID 有 10 个数据点,因此它只会平均最低的 8 个值 (80%)。

Mik*_*son 5

您可以使用ntile

select OpID,
       avg(ProcessMin) as ProcessMin
from
  (
    select OpID,
           ProcessMin,
           ntile(5) over(partition by OpID order by ProcessMin) as nt
    from YourTable
  ) as T
where nt <= 4
group by OpID
Run Code Online (Sandbox Code Playgroud)

SE数据

如果 ProcessMin 是integer您可以avg(cast(ProcessMin as float)) as ProcessMin获取小数平均值的方法。