VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 编程开发 > c#教程 >
  • C#教程之C#教程之【转载】Sqlserver数据库中无自增Id的情况

本站最新发布   C#从入门到精通
试听地址  
https://www.xin3721.com/eschool/CSharpxin3721/

在Sqlserver数据库中,如果查询表中含有自增长Id列,一般会采用select Top的方式来数据的分页操作。而实际上很多数据表设计的时候,不一定含有自增长Id列,那么数据库没有Id自增列的时候要对数据分页怎么办呢,此时则需要使用ROW_NUMBER()函数来对数据分页,ROW_NUMBER()一般与OVER(order by)一起连用。 

使用Row_Number来数据分页的格式如下:

复制代码
With tempTb AS
(
   Select ROW_NUMBER() OVER(order by 排序的列 ASC) AS RowNumber,* FROM 数据表_Table
)

Select * FROM tempTb  Where RowNumber>开始行号  AND RowNumber<结束行号;
复制代码

举个例子,我们要查询Student表中的学生数据,按学生出生日期从前到后排序,取出出生日期排在第31位到第60位的数据,语句如下:

With tempTb AS
(
   Select ROW_NUMBER() OVER(order by BirthDay ASC) AS RowNumber,* FROM Student
)
Select * FROM tempTb Where RowNumber>30 AND RowNumber<=60

 

扩展阅读:目前国内主流的云服务器厂商有哪些_IT技术小趣屋。

备注:原文转载自Sqlserver使用ROW_NUMBER()函数进行数据分页_IT技术小趣屋。

 
 

相关教程