sql 分页sql语句与存储过程

select * from 
(select  sm.userid, sm.ip,e.id ,row_number() over(order by sm.userid)as serialNum from dbo.Staff_Main sm 
left join dbo.Evaluation e  on sm.userid=e.userid) T 
where T.serialNum>5 and T.serialNum<=10

自己写的一个简单sql语句分页

 

2SQL SERVER 2005中的TOP分页

CREATE PROCEDURE [dbo].[Zhzuo_GetItemsPage2005TOP]
    @PageIndex INT,
    @PageSize  INT,
    @RecordCount INT OUT,
    @PageCount INT OUT
AS 
/*获取记录数*/
SELECT @RecordCount = COUNT(*FROM Production.Product
/*计算页面数据*/
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
/*TOP记录数*/
DECLARE @TOPCOUNT INT
SET @TOPCOUNT = @RecordCount - @PageSize * @PageIndex 

/*基于SQL SERVER 2005 */
IF @PageIndex = 0 OR @PageCount <= 1
BEGIN
    SELECT TOP(@PageSize) ProductID,Name FROM Production.Product ORDER BY ProductID DESC
END
ELSE
BEGIN 
    IF @PageIndex = @PageCount - 1
    BEGIN
       SELECT * FROM ( SELECT TOP(@TOPCOUNT) ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T
       ORDER BY ProductID DESC
    END
    ELSE
    BEGIN
       SELECT TOP(@PageSize* FROM (SELECT TOP(@TOPCOUNT) ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T
       ORDER BY ProductID DESC
    END
END 

 

以上存储过程是使用2005TOP (表达式新功能,避免了字符串拼串,使结构化查询语言变得简洁。实现的为同样的功能。 
3SQL SERVER 2005中的新分页
CREATE PROCEDURE [dbo].[Zhzuo_GetItemsPage2005]
    @PageIndex INT,
    @PageSize  INT,
    @RecordCount INT OUT,
    @PageCount INT OUT
AS 
/*获取记录数*/
SELECT @RecordCount = COUNT(*FROM Production.Product
/*计算页面数据*/
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
/* 基于SQL SERVER 2005 */
SELECT SerialNumber,ProductID,Name FROM
(SELECT ProductID,Name,ROW_NUMBER() OVER (ORDER BY ProductID DESCAS SerialNumber FROM Production.Product ) AS T
WHERE T.SerialNumber > (@PageIndex * @PageSize)  and T.SerialNumber <= ((@PageIndex+1* @PageSize)

第三个存储过程使用2005下新的功能,实现的分页存储过程功能更加简单明了,而且更加容易理解。注意这里的ProductID为主键,根据ProductID进行排序生成ROW_NUMBER,通过ROW_NUMBER来确定具体的页数。 
通过对三个分页存储过程的比较,可见SQL SERVER TSQL 语言对分页功能的支持进步不少。使分页实现趋向于简单化
posted @ 2014-06-19 14:19  nik2011  阅读(113)  评论(0)    收藏  举报