首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >限制每个ID的行数

限制每个ID的行数
EN

Stack Overflow用户
提问于 2013-04-25 22:34:25
回答 1查看 1.1K关注 0票数 2

我正在尝试将每个案例的行数限制为只有5行。有些情况下只有1到2行,但有些情况下有15行或更多行。

这是一个存储过程的示例,我使用它来计算每个case的行数。

代码语言:javascript
复制
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条?

提前感谢您的帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-25 22:36:00

您可以将语句包装在CTE中,因为SQL Server支持它。

代码语言:javascript
复制
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
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16217612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档