限制每个 ID 的行数

Posted

技术标签:

【中文标题】限制每个 ID 的行数【英文标题】:Limit the number of rows per ID 【发布时间】:2013-04-25 14:34:24 【问题描述】:

我试图将每个案例的行数限制为 5 行。有些案例只有 1 或 2 行,但有些案例有 15 行或更多。

这是我用来计算每个案例的行数的存储过程示例。

SELECT     ROW_NUMBER() OVER(partition by rce.reportruncaseid ORDER BY rce.Reportruncaseid) AS Row, rce.ReportRunCaseId AS CaseId, YEAR(rce.EcoDate) AS EcoYear
FROM         PhdRpt.ReportCaseList AS rcl INNER JOIN
                  PhdRpt.RptCaseEco AS rce ON rce.ReportId = rcl.ReportId AND rce.ReportRunCaseId = rcl.ReportRunCaseId
GROUP BY rce.ReportId, rce.ReportRunCaseId, YEAR(rce.EcoDate)
Order by rce.ReportRunCaseId, YEAR(rce.EcoDate)

这里是这个存储过程产生的截图:screenshot

我尝试使用 where 子句,但它不允许我在 where 子句之后放置窗口函数。它也无法识别我的“Row”别名。

是否有另一种方法来计算每个案例的数量或行数(而不是窗口函数),以便我可以使用 where 子句?或者有没有办法使用我现有的存储过程将每个案例的记录限制为 5?

提前感谢您的帮助。

【问题讨论】:

【参考方案1】:

您可以将您的声明包装在CTE 中,因为SQL Server 支持它。

WITH records
AS
(
    SELECT  ROW_NUMBER() OVER(PARTITION BY rce.reportruncaseid 
                              ORDER BY rce.Reportruncaseid) AS Row, 
            rce.ReportRunCaseId AS CaseId, 
            YEAR(rce.EcoDate) AS EcoYear
    FROM    PhdRpt.ReportCaseList AS rcl 
                INNER JOIN PhdRpt.RptCaseEco AS rce 
                    ON  rce.ReportId = rcl.ReportId 
                        AND rce.ReportRunCaseId = rcl.ReportRunCaseId
    GROUP   BY rce.ReportId, rce.ReportRunCaseId, YEAR(rce.EcoDate)
)
SELECT CaseId, EcoYear
FROM   records
WHERE  row <= 10
ORDER  BY CaseId, EcoYear

【讨论】:

非常感谢。这完美地工作。如果我需要添加更多列,我会将它们添加到第一个 select 语句还是第二个? 您需要将它们添加到CTE 子句中。外部语句上的记录,基于CTE

以上是关于限制每个 ID 的行数的主要内容,如果未能解决你的问题,请参考以下文章

Node.js:计算文件中的行数

Xcode:如何快速判断哪些文件的行数超出了最大列限制?

使用 jQuery 限制 textarea 中的行数和显示行数

作业-- 统计文本文件中的字符数单词数行数

计算日期范围内每个日期的行数

python脚本: 双向统计文件字符单词数行数