获取resultset sql server中的记录行数

时间:2010-11-03 19:32:51

标签: sql sql-server tsql

我有一个包含序列号的文件表 - 列:

  • docid int
  • 撰写文字
  • submissionDate datetime

...我想知道特定序列号在针对该表的查询中的位置。

例如,如果我通过submissionDate asc命令结果集,我可能想知道文档34在该排序中的位置(即它在第11位?)

我该怎么做?

3 个答案:

答案 0 :(得分:5)

SQL Server 2005+,使用分析函数:

SELECT t.docid,
       t.writing,
       t.submissiondate,
       ROW_NUMBER() OVER(ORDER BY t.submissiondate) AS position
  FROM YOUR_TABLE t

非分析版

此方法存在非连续值的风险,因为如果有两个(或更多)具有相同submissiondate值的记录 - 它们都将具有相同的位置值。它与使用RANK或DENSE_RANK分析函数相同,因为ROW_NUMBER将始终为每条记录授予唯一值,而不考虑重复值。

SELECT x.docid,
       x.writing,
       x.submissiondate,
       (SELECT COUNT(*)
          FROM YOUR_TABLE y
         WHERE y.submissiondate <= x.submissiondate) AS position
  FROM YOUR_TABLE x

答案 1 :(得分:2)

您可以使用窗口函数rank()

示例(from MSDN):

SELECT i.ProductID, p.Name, i.LocationID, i.Quantity
    ,RANK() OVER (ORDER BY i.Quantity DESC) AS 'RANK'
  FROM Production.ProductInventory i 
 INNER JOIN Production.Product p  ON i.ProductID = p.ProductID
 ORDER BY p.Name;

它非常强大。

它是SQL标准,它应该适用于SQL Server 2005和更新版本。

答案 2 :(得分:2)

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