rownumber函数的使用

rownumber函数的使用

ID:34725583

大小:117.99 KB

页数:4页

时间:2019-03-10

rownumber函数的使用_第1页
rownumber函数的使用_第2页
rownumber函数的使用_第3页
rownumber函数的使用_第4页
资源描述:

《rownumber函数的使用》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

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

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

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

4、dersWITH(NOLOCK)6ORDERBY字段编号ASC下边来看一个对ROW_NUMBER()函数的简单分页应用。Code1--PartitionPageDemo2/**//*取出第-200条的记录(记录须按OrderID排序)*/34WITHOrdersByOrderIDASCAS5(6SELECTOrderID,7CustomerID,8OrderDate,9ROW_NUMBER()OVER(ORDERBYorderIDASC)AS字段编号10FROMdbo.OrdersWITH(NOLOCK)11)1213SELECT*14FROMOr

5、dersByOrderIDASCWITH(NOLOCK)15WHERE字段编号BETWEEN100AND110首先把应用ROW_NUMBER()函数后的结果集存在一张临时表中,然后以字段编号这个字段为条件,使用BETWEEN关键字过滤相应的记录。以上就是我对ROW_NUMBER()函数的一点粗浅认识,希望可以帮到大家!

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。