sql server 2005 新分页存储过程create   PROCEDURE [dbo].[PagingRecord]
sql server 2005 新分页存储过程    ( 
sql server 2005 新分页存储过程    
@PageIndex int,--页号,从0开始
sql server 2005 新分页存储过程
    @PageSize int,--页尺寸
sql server 2005 新分页存储过程
    @OrderField varchar(100),--排序字段及类型(多个条件用逗号分开)如:JobID DESC,Checkintime
sql server 2005 新分页存储过程
    @TableName varchar(100),--表名或视图表 
sql server 2005 新分页存储过程
    @FieldList varchar(2000),--欲选择字段列表      
sql server 2005 新分页存储过程
    @DoCount  AS bit=1-- 0值返回记录总数, 非 0 值则返回记录
sql server 2005 新分页存储过程
    ) 
sql server 2005 新分页存储过程
AS 
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程
DECLARE @SqlQuery varchar(4000)
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程
IF @DoCount<>0--需要返回记录总数
sql server 2005 新分页存储过程
begin
sql server 2005 新分页存储过程    
DECLARE @SearchSql AS Nvarchar(4000)
sql server 2005 新分页存储过程    
SET @SearchSql= 'SELECT Count(*) AS Total FROM '+@tablename
sql server 2005 新分页存储过程    
exec sp_executesql @SearchSql
sql server 2005 新分页存储过程    
--print @SearchSql 
sql server 2005 新分页存储过程
end
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程
sql server 2005 新分页存储过程    
SET @SqlQuery='SELECT '+@FieldList+'
sql server 2005 新分页存储过程    FROM (SELECT row_number() over(ORDER BY 
'+@OrderField+') as rownum, 
sql server 2005 新分页存储过程            
'+@FieldList+'
sql server 2005 新分页存储过程          FROM 
'+@TableName+') as temp
sql server 2005 新分页存储过程    WHERE rownum BETWEEN (
'+cast(@PageIndex as varchar)+'-1)*'+cast(@PageSize as varchar)+'+1 and '+cast(@PageIndex as varchar)+'*'+cast(@PageSize as varchar)+'
sql server 2005 新分页存储过程    ORDER BY 
'+@OrderField
sql server 2005 新分页存储过程    
--print @SqlQuery
sql server 2005 新分页存储过程
    SET NOCOUNT ON
sql server 2005 新分页存储过程    
execute(@SqlQuery)
sql server 2005 新分页存储过程    
SET NOCOUNT OFF
注意事项:
传入的那个table字符串,你可以后面加上 where 条件拼接起来。
如果需要返回总查询量,最后那个参数 @DoCount 传递 1 进去,不然传递 0 进去。

这个是这篇文章的改编   http://www.cnblogs.com/Randy0528/archive/2007/02/05/640788.html  

相关文章: