我有一张桌子,上面满是带有序号的文档-列:
…并且我想找出特定序列号在针对该表的查询中的位置。
例如,如果我按submittingDate asc对结果集进行排序,则我可能想知道文档34在该排序中的位置(即它在位置11中吗?)
我该怎么做呢?
看起来您正在尝试获取行号,即使该行号不是要返回的行之一。您可以为此使用CTE:
;WITH CTE AS ( SELECT docid, writing, submissionDate, ROW_NUMBER() OVER (ORDER BY submissionDate) AS position FROM My_Table ) SELECT docid, writing, submissionDate, position FROM CTE WHERE docid = 34
当然,这也需要SQL Server 2005或更高版本。