每个组SQL Server的前n个的平均值

时间:2012-04-13 18:51:19

标签: sql-server-2008 group-by average 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

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

*更新*

鉴于下表:

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

我希望这个输出:

OptID   ProcessMin
602     41
603     34.125

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

1 个答案:

答案 0 :(得分:4)

您可以使用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

SE-Data

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