rownumber函数的使用

上传人:xiao****1972 文档编号:84087103 上传时间:2019-03-02 格式:DOCX 页数:4 大小:83.81KB
返回 下载 相关 举报
rownumber函数的使用_第1页
第1页 / 共4页
rownumber函数的使用_第2页
第2页 / 共4页
rownumber函数的使用_第3页
第3页 / 共4页
rownumber函数的使用_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《rownumber函数的使用》由会员分享,可在线阅读,更多相关《rownumber函数的使用(4页珍藏版)》请在金锄头文库上搜索。

1、ROW_NUMBER()函数是Sql 2005中新添的一个函数。通常它被用在分页的SQL语句中。微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。 上边可能说的不是很清楚,请结合下边这个例子来看吧! Code 1USE Northwind 2GO 3 4- 5SELECT OrderID, 6 CustomerID, 7 OrderDate 8FROM dbo.Orders WITH(NOLOCK) 910

2、SELECT OrderID, 11 CustomerID, 12 OrderDate, 13 ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号14FROM dbo.Orders WITH(NOLOCK)第一个查询只是一个普通的查询,查询出Orders表中的3个字段的记录。其结果为: 第二个查询相比第一个查询仅仅是多了“ ROW_NUMBER() OVER(ORDER BY orderID DESC) AS 字段编号 ”这段语句。我们来分析一下这段语句。这段语句的作用就是利用ROW_NUMBER()函数根据OrderID这列来生成一个新的数据列,

3、这列的名称为字段编号。然后我们根据ORDER BY orderID DESC来指定字段编号这列按照OrderID的逆序来生成,结果如下: 比较两个结果集,会发现第二个结果集是按照OrderID字段逆序的记录,其实也可看成是字段编号这个字段的正序排序,ROW_NUMBER()函数相当于为SELECT语句末尾加了ORDER BY子句,第二个SELECT语句其实等价于: Code1SELECT OrderID, 2 CustomerID, 3 OrderDate, 4 ROW_NUMBER() OVER(ORDER BY OrderID DESC) AS 字段编号5FROM dbo.Orders W

4、ITH(NOLOCK)6ORDER BY 字段编号ASC 下边来看一个对ROW_NUMBER()函数的简单分页应用。 Code 1-Partition Page Demo 2/*/* 取出第- 200条的记录(记录须按OrderID排序)*/ 3 4WITH 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)1213SELECT * 14FROM OrdersByOrderIDASC WITH(NOLOCK)15WHERE 字段编号BETWEEN 100 AND 110 首先把应用ROW_NUMBER()函数后的结果集存在一张临时表中,然后以字段编号这个字段为条件,使用BETWEEN关键字过滤相应的记录。 以上就是我对ROW_NUMBER()函数的一点粗浅认识,希望可以帮到大家!

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号