子曾经曰过

  博客园  :: 首页  ::  ::  ::  :: 管理

SELECT TOP(分页大小) *
FROM
(
SELECT ROW_NUMBER() OVER (ORDER BY 排序条件) AS RowNo FROM 数据表
)
AS T
WHERE RowNo > ((目前页数 - 1) * 分页大小)


假设我们的 GridView 每页要显示 10 笔记录,user 目前在 GridView 的第 20 页,当他单击「下一页」或第 21 页的页码时,就去 SQL Server 2005 撷取第 201 ~ 210 笔记录,在 Stored Procedure 里即执行下列 SQL 语句。撷取结果如下图 3 所示:

SELECT TOP(10) *
FROM
(
SELECT OrderID, CustomerID, OrderDate, ROW_NUMBER() OVER (ORDER BY OrderID DESC) AS 字段编号 FROM Orders
)
AS 暂存表 WHERE 字段编号 > ((21 - 1) * 10)
posted on 2011-03-06 17:58  人的本质是什么?  阅读(152)  评论(0编辑  收藏  举报