您的位置:首页 > 数据库

利用SQL2005的row_number()重新写了个自定义分页存储过程

2009-09-17 16:56 706 查看
--@Tablename 表名
--@Orderby 排序的字段名
--@Index 页码
--@Size 页大小
ALTER PROCEDURE uspPaging @Tablename varchar(20),@Orderby varchar(20),@Index int=1,@Size int=10
AS
BEGIN
DECLARE @sql VARCHAR(500)
SET @sql='SELECT * FROM
(SELECT ROW_NUMBER() OVER(ORDER BY '+@Orderby+') AS ID,* FROM '+@Tablename+')
AS temp WHERE ID BETWEEN ('+CAST(@index AS VARCHAR(5))+'-1)*'+CAST(@size AS VARCHAR(5))+'+1 AND '+CAST(@index*@size AS VARCHAR(5))
EXEC(@sql)
END

例子:Northwind数据库
EXEC uspPaging 'Products','ProductID',3,3
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: