T-SQL SELECT DISTINCT & ROW_NUMBER() OVER Ordering Problem

可紊 提交于 2019-12-01 19:07:47

问题


I'm trying to select DISTINCT rows from a view using ROW_NUMBER() OVER for paging. When I switched the ORDER BY field from a SMALLDATETIME to INT I started getting weird results:

SELECT RowId, Title, HitCount FROM
( SELECT DISTINCT Title, HitCount, ROW_NUMBER() OVER(ORDER BY HitCount DESC) AS RowId FROM ou_v_Articles T ) AS Temp
WHERE RowId BETWEEN 1 AND 5

This query returns:

RowId | Title | HitCount
=======================
4  ---  9
1  ---  43
3  ---  11
2  ---  13
5  ---  0

The results are obviously not in the correct order. I'm not sure what the problem is here, but when I removed DISTINCT it orders them correctly.

Thanks.


回答1:


Is the RowId value you're getting correct? Perhaps you just need an ORDER BY RowId clause on the outer query?




回答2:


Applying DISTINCT to a column list containing ROW_NUMBER() will always result in every row being distinct, as there is one ROW_NUMBER per row.




回答3:


Have you tried just using an order by on the outer select and removing the OVER clause?



来源:https://stackoverflow.com/questions/2293987/t-sql-select-distinct-row-number-over-ordering-problem

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!