文档详情

SQL 分页应用 ROW_NUMBER函数的使用.doc

发布:2015-09-23约1.36千字共3页下载文档
文本预览下载声明
SQL 分页应用 ROW_NUMBER()函数的使用 ROW_NUMBER()函数是Sql?2005中新添的一个函数。 通常它被用在分页的SQL语句中。 微软官方的对此函数的描述是:返回结果集分区内行的序列号,每个分区的第一行从?1?开始。 我对此的理解:利用此函数可以为表中的某个字段建立序列,从1开始。就是说,根据已存在的某列,利用此函数可建立一新列,新列是数字,按照已存在列的顺序从1开始。 ???上边可能说的不是很清楚,请结合下边这个例子来看吧! ? ?1USE?Northwind ?2GO ?3 ?4-- ?5SELECT?OrderID,? ?6????CustomerID,? ?7????OrderDate ?8FROM?dbo.Orders?WITH(NOLOCK) ?9 10SELECT?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()ORDER?BY?orderID?DESC来指定字段编号这列按照OrderID的逆序来生成,结果如下: ? 比较两个结果集,会发现第二个结果集是按照ROW_NUMBER()函数相当于为SELECT语句末尾加了ORDER?BY子句,第二个SELECT语句其实等价于: ? 1SELECT?OrderID,? 2????CustomerID,? 3????OrderDate,? 4????ROW_NUMBER()?OVER(ORDER?BY?OrderID?DESC)?AS?字段编号 5FROM?dbo.Orders?WITH(NOLOCK) 6ORDER?BY?字段编号ASC ? ROW_NUMBER()函数的简单分页应用。 ? ?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) 12 13SELECT?*? 14FROM?OrdersByOrderIDASC?WITH(NOLOCK) 15WHERE?字段编号BETWEEN?100?AND?110 ? ROW_NUMBER()函数后的结果集存在一张临时表中,然后以字段编号这个字段为条件,使用BETWEEN关键字过滤相应的记录。
显示全部
相似文档