Номер строки прерывается при использовании с CTE

Это мой запрос, SQL внутри CTE работает нормально, и все, что я хочу получить первые 20 строк для каждого названия города:

WITH taniCte
AS (
    SELECT sl.Adi AS [CityName],
        mt.ICD10Kodu AS [Tanı],
        count(mt.ICD10Kodu) AS sayi,
        RowNum = ROW_NUMBER() OVER (
            ORDER BY sl.Adi
            )
    FROM Muayene.Muayene mm WITH (NOLOCK)
    INNER JOIN Muayene.Tani mt WITH (NOLOCK) ON mm.ID = mt.MuayeneId
    INNER JOIN Ortak.Kurum ok WITH (NOLOCK) ON mm.CreatedKurumKodu = ok.KurumKodu
    INNER JOIN Skrs.Il sl WITH (NOLOCK) ON ok.IlKodu = sl.Kodu
    GROUP BY sl.Adi,
        mt.ICD10Kodu
    ) --order by [CityName], sayi desc // commentewhen its moved inside cte
SELECT [CityName],
    [Tanı],
    sayi,
    RowNum
FROM taniCte
WHERE RowNum <= 20
ORDER BY [CityName],
    sayi DESC

Eventhough основной запрос работает нормально запрос выше возвращает неправильные строки..

Я не мог найти никакого решения в интернете

1 ответ

Решение

Если вам нужно 20 строк в каждом городе, тогда ваше предложение row_number OVER в cte должно быть

with taniCte as
(
  select sl.Adi as [CityName]
       , mt.ICD10Kodu as [Tanı]
       , count(mt.ICD10Kodu) as sayi
       , RowNum = ROW_NUMBER()OVER(partition By sl.Adi order by count(mt.ICD10Kodu)) -- this change in over clause
  from Muayene.Muayene mm with(nolock)
       join Muayene.Tani mt with(nolock) on mm.ID = mt.MuayeneId
       join Ortak.Kurum ok with(nolock) on mm.CreatedKurumKodu = ok.KurumKodu
       join Skrs.Il sl with(nolock) on ok.IlKodu = sl.Kodu
   group by sl.Adi, mt.ICD10Kodu 
   --order by [CityName], sayi desc // commentewhen its moved inside cte
)
select [CityName], [Tanı],sayi, RowNum 
from taniCte 
where RowNum <= 20 
order by [CityName], sayi desc
Другие вопросы по тегам