找回密码
 注册
搜索
热搜: java php web
查看: 2584|回复: 6

SQL server中如何实现自定义分页

[复制链接]
发表于 2009-1-26 06:52:45 | 显示全部楼层 |阅读模式
代码如下:
示例代码都以下面的表结构为准:
    Articles 表     SQL Server 类型          Oracle 类型
PK  Id             int (自增) number(9)   (插入时在当前最大值上加1)
   Author          nvarchar(10)           nvarchar2(10)
   Title           nvarchar(50)           nvarchar2(50)
   PubTime         datetime               date
SQL Server / Access 等微软产品中,我们通常的自定义分页有两种思路:

一种是以 ASP.NET Forum 为代表的、“临时表”方法:即在存储过程中建立一个临时表,该临时表包含一个序号字段(1,2,3,....)以及表的主键(其他能够唯一确定一行记录的字段也是可以的)字段。存储过程可能如下:(1)

复制内容到剪贴板
代码:
CREATE Procedure GetAllArticles_Paged
(
     @PageIndex int,
     @PageSize int,
     @TotalRecords out int,
     @TotalPages out int
)
AS

DECLARE @PageLowerBound int
DECLARE @PageUpperBound int

-- Set the page bounds
SET @PageLowerBound = @PageSize * @PageIndex
SET @PageUpperBound = @PageLowerBound + @PageSize + 1

-- Create a temp table to store the select results
CREATE TABLE #tmp
(
     RecNo int IDENTITY (1, 1) NOT NULL,
     ArticleID int
)

INSERT INTO #tmp
     SELECT [ID]
     FROM Articles
     ORDER BY PubTime DESC

SELECT A.*
FROM Articles A (nolock), #tmp T
WHERE A.ID = T.ArticleID AND
     T.RecNo > @PageLowerBound AND
     T.RecNo < @PageUpperBound
ORDER BY T.RecNo

GO
另一种可能更适合程序中“拼凑” SQL 语句:用两次 TOP 命令取得我们所要的分页数据,例如:(2)
复制内容到剪贴板
代码:
SELECT * FROM
     (
     SELECT TOP(PageSize) * FROM
     (
          SELECT TOP (PageSize * PageIndex) *
          FROM Articles
          ORDER BY PubTime DESC
     )
     ORDER BY PubTime ASC
)
ORDER BY PubTime DESC
这个的想法就是“掐头去尾”,还有不少分页的方法,这里就不一一列出了。

对于 Oracle 数据库,有几处不同严重妨碍了上面几个方法的实施,比如,Oracle 不支持 TOP 关键字:不过这个好像并不十分严重,因为它提供了 rownum 这个隐式游标,可以实现与 TOP 类似的功能,如:
SELECT TOP 10 ... FROM WHERE ...
要写成
SELECT ... FROM ... WHERE ... AND rownum <= 10
rownum 是记录序号(1,2,3...),但有一个比较麻烦的事情是:如果 SQL 语句中有 ORDER BY ... 排序的时候,rownum 居然是先“标号”后排序!这样,这个序号如果不加处理是不合乎使用需求的。

至于临时表,Oracle 的临时表和 SQL Server 的有很大不同,我还没搞懂这个东西,就不妄加揣测了。

国内网站中介绍 Oracle 分页的资料很少,我找到了一个国外站点(www.faqts.com)的一篇 FAQ,根据这篇文章的介绍,可以如下分页:(编号 3)
复制内容到剪贴板
代码:
SELECT * FROM
     (
     SELECT A.*, rownum r
     FROM
          (
          SELECT *
          FROM Articles
          ORDER BY PubTime DESC
          ) A
     WHERE rownum <= PageUpperBound
     ) B
WHERE r > PageLowerBound;
如果大家有兴趣的可以继续谈谈你们的想法和算法,共同学习
发表于 2009-1-26 07:27:45 | 显示全部楼层
正是我想要的不错
回复

使用道具 举报

发表于 2009-1-26 07:24:35 | 显示全部楼层
回复 1# 的帖子
回复

使用道具 举报

发表于 2009-1-26 08:22:21 | 显示全部楼层
谢谢!!!!
回复

使用道具 举报

发表于 2009-1-26 09:03:49 | 显示全部楼层
回复

使用道具 举报

发表于 2009-1-26 08:13:08 | 显示全部楼层
收下了  很不错的   正好要用到
回复

使用道具 举报

发表于 2009-1-26 08:51:47 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|软晨网(RuanChen.com)

GMT+8, 2025-1-18 18:46

Powered by Discuz! X3.5

Copyright © 2001-2023 Tencent Cloud.

快速回复 返回顶部 返回列表