2

ケースごとの行数を 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)

このストアド プロシージャが生成するもののスクリーンショットを次に示します

where 句を使用しようとしましたが、where 句の後にウィンドウ関数を配置できません。また、「Row」エイリアスも認識しません。

where句を使用できるように、(ウィンドウ関数の代わりに)ケースごとに数または行をカウントする別の方法はありますか?または、既存のストアド プロシージャを使用して、ケースごとのレコードを 5 に制限する方法はありますか?

よろしくお願いいたします。

4

1 に答える 1

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
于 2013-04-25T14:35:59.747 に答える