当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server 2000/2005 分页SQL

MSSQL
SQL Server数据库技术(60)
SQL Server数据库技术(61)
SQL Server数据库技术(62)
SQL Server数据库技术(63)
SQL Server数据库技术(64)
SQL Server数据库技术(66)
SQL Server数据库技术(67)
SQL Server数据库技术(69)
SQL Server数据库技术(70)
SQL Server数据库技术(71)
SQL Server数据库技术(72)
SQL Server数据库技术(73)
SQL Server数据库技术(74)
SQL Server数据库技术(75)
SQL Server数据库技术(76)
SQL Server数据库技术(77)
SQL Server数据库技术(78)
SQL Server数据库技术(79)
SQL Server数据库技术(80)
SQL Server数据库技术(81)

MSSQL 中的 SQL Server 2000/2005 分页SQL


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 120 ::
收藏到网摘: n/a

有关分页 SQL 的资料很多,有的使用存储过程,有的使用游标。本人不喜欢使用游标,我觉得它耗资、效率低;使用存储过程是个不错的选择,因为存储过程是经过预编译的,执行效率高,也更灵活。先看看单条 SQL 语句的分页 SQL 吧。

方法1:
适用于 SQL Server 2000/2005
 

SELECT TOP 页大小 *
FROM table1
WHERE id NOT IN
          (
          
SELECT TOP 页大小*(-1) id FROM table1 ORDER BY id
          )
ORDER BY id


方法2:
适用于 SQL Server 2000/2005

SELECT TOP 页大小 *
FROM table1
WHERE id >
          (
          
SELECT ISNULL(MAX(id),0
          FROM 
                (
               
SELECT TOP 页大小*(-1) id FROM table1 ORDER BY id
                ) 
A
          )
ORDER BY id


方法3:
适用于 SQL Server 2005

 

SELECT TOP 页大小 * 
FROM 
        (
        
SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM table1
        ) A
WHERE RowNumber > 页大小*(页数-1)


说明,页大小:每页的行数;页数:第几页。使用时,请把“页大小”和“页大小*(页数-1)”替换成数字。