ROW_NUMBER()函数是Sql 2005中新添的一个函数。通常它被用在分页的SQL语句中。
微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。
上边可能说的不是很清楚,请结合下边这个例子来看吧!

Code
1
USE Northwind
2
GO
3
4
--
5
SELECT OrderID,
6
CustomerID,
7
OrderDate
8
FROM dbo.Orders WITH(NOLOCK)
9
10
SELECT OrderID,
11
CustomerID,
12
OrderDate,
13
ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号
14
FROM dbo.Orders WITH(NOLOCK)
第一个查询只是一个普通的查询,查询出Orders表中的3个字段的记录。其结果为:

第二个查询相比第一个查询仅仅是多了“ ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号 ”这段语句。我们来分析一下这段语句。
这段语句的作用就是利用ROW_NUMBER()函数根据OrderID这列来生成一个新的数据列,这列的名称为字段编号。然后我们根据ORDER BY orderID DESC来指定字段编号这列按照OrderID的逆序来生成,结果如下:

比较两个结果集,会发现第二个结果集是按照OrderID字段逆序的记录,其实也可看成是字段编号这个字段的正序排序,ROW_NUMBER()函数相当于为SELECT语句末尾加了ORDER BY子句,第二个SELECT语句其实等价于:

Code
1
SELECT OrderID,
2
CustomerID,
3
OrderDate,
4
ROW_NUMBER() OVER(ORDER BY OrderID DESC) AS 字段编号
5
FROM dbo.Orders WITH(NOLOCK)
6
ORDER BY 字段编号ASC
下边来看一个对ROW_NUMBER()函数的简单分页应用。

Code
1
--Partition Page Demo
2
/**//* 取出第- 200条的记录(记录须按OrderID排序)*/
3
4
WITH OrdersByOrderIDASC AS
5
(
6
SELECT OrderID,
7
CustomerID,
8
OrderDate,
9
ROW_NUMBER() OVER(ORDER BY orderID ASC) AS 字段编号
10
FROM dbo.Orders WITH(NOLOCK)
11
)
12
13
SELECT *
14
FROM OrdersByOrderIDASC WITH(NOLOCK)
15
WHERE 字段编号BETWEEN 100 AND 110
首先把应用ROW_NUMBER()函数后的结果集存在一张临时表中,然后以字段编号这个字段为条件,使用BETWEEN关键字过滤相应的记录。
以上就是我对ROW_NUMBER()函数的一点粗浅认识,希望可以帮到大家!