2007-01-26

如何实现SQL Server 2005快速web分页

来源: 本站收集整理 作者:佚名 评论 0 条
 

SELECT
PageNumber, SaleID, Product, SaleDate, SalePrice
FROM
Sales_CTE
WHERE
PageNumber = @Targetpage
ENDCREATE PROCEDURE usp_SalesRecords
(
@PageSize FLOAT,
@TargetPage SMALLINT
)
AS
BEGIN
WITH Sales_CTE(PageNumber, SaleID, Product, SaleDate, SalePrice)
AS
(
SELECT
CEILING((ROW_NUMBER() OVER (ORDER BY SaleDate ASC))/@PageSize) AS PageNumber, SaleID, Product, SaleDate, SalePrice
FROM SalesHistory FROM SalesHistory
)

SELECT
PageNumber, SaleID, Product, SaleDate, SalePrice
FROM
Sales_CTE
WHERE
PageNumber = @Targetpage
END

假如你刚刚开始使用SQL Server,可能会不熟悉以“WITH”开头的声明语句。这条语句会调用SQL Server中的一个新属性,我们称之为common table expressionCTE),从本质上来说,我们可以将CTE看作是高版本的临时表。

分页的实质就是CTE中的TSQL语句。在下面的选择语句中,我使用了一个新的排序函数——ROW_NUMBER(这一函数很轻易使用,你只需要给ROW_NUMBER函数提供一个域名作为参数,ROW_NUMBER会用它来进行分页)。随后,我使用@PageSize参数来划分每页的行数以及每页的最大行数值。

例如,假设现在有一个包含三条记录的数据集,并设计每页显示两条记录,那么头两条记录将会在第一页显示,因为每页的行数必须小于或者等于第一个变量值。第三条记录将会在第二页显示,因为每页的可显示最大行数值应该小于2但是又大于1。
可以使用下面的脚本调用存储程序:
EXECUTE usp_SalesRecords
@PageSize = 3,
@TargetPage = 2

执行程序后的返回结果如下:
PageNumber
SaleID
Product
SaleDate
SalePrice
2
12
PoolTable
7/11/1908
0:00
640
2
15
PoolTable
8/11/1908
0:00
641
2
18
PoolTable
9/11/1908
0:00
658
就如你所看到的,程序执行后将会返回一页的数据,包含三条记录,而且返回的是第二页的数据集。

需要注重的一点

一般来说,有两种方法完成数据结果的分页:在数据库层实现和不在数据库层实现。可以在客户端实现分页,但是这样做的时候,所有的数据都会返回到客户端,而且在进行数据分析的时候就决定了页面数目。在早期版本的SQL Server中,可以在数据库层实现分页,但是需要临时表和表变量。假如上面的例子没有使用CTE来进行分页的话,分页程序就不会那么简单。之所以这么简单就是因为使用了ROW_NUMBER函数的强大功能。在以后的文章中,我将会大概介绍一下其它三种排列函数,并展示它们提供的一些灵活易用的函数功能。
共3页: 上一页 [1] 2 [3] 下一页
(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:SQL Server和Oracle数据锁定比较  
下一篇:sql server的保留关键字
    评论加载中…
 热门排行
 推荐文章
     

 相关文章
网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号