一尘不染

获取结果集SQL Server中记录的行号

sql

我有一张表,上面满是带有序号的文档-列:

  • docid int
  • writing text
  • submissionDate datetime

…并且我想找出特定序列号在针对该表的查询中的位置。

例如,如果我按submittingDate asc对结果集进行排序,则我可能想知道文档34在该排序中的位置(即它在位置11中吗?)

我该怎么做呢?


阅读 177

收藏
2021-05-30

共1个答案

一尘不染

看起来您正在尝试获取行号,即使该行号不是要返回的行之一。您可以为此使用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或更高版本。

2021-05-30