sqlserver 通用分页存储过程

简介: 来源:http://www.jb51.net/article/19936.htm CREATE PROCEDURE commonPagination @columns varchar(500), --要显示的列名,用逗号隔开 @tableName varchar(100), --要查询...
+关注继续查看

来源:http://www.jb51.net/article/19936.htm

CREATE  PROCEDURE commonPagination
@columns varchar(500), --要显示的列名,用逗号隔开 
@tableName varchar(100), --要查询的表名 
@orderColumnName varchar(100), --排序的列名 
@order varchar(50), --排序的方式,升序为asc,降序为 desc 
@where varchar(100), --where 条件,如果不带查询条件,请用 1=1 
@pageIndex int, --当前页索引 
@pageSize int, --页大小(每页显示的记录条数) 
@pageCount int  --总页数,输出参数 
as 
begin 
    declare @sqlRecordCount nvarchar(1000) --得到总记录条数的语句 
    declare @sqlSelect nvarchar(1000) --查询语句 
    set @sqlRecordCount=N'select @recordCount=count(*) from ' +@tableName + ' where '+ @where 
    
    declare @recordCount int --保存总记录条数的变量 
    exec sp_executesql @sqlRecordCount,N'@recordCount int output',@recordCount output 
    
    --动态 sql 传参 
    if( @recordCount % @pageSize = 0) --如果总记录条数可以被页大小整除 
        set @pageCount = @recordCount / @pageSize --总页数就等于总记录条数除以页大小 
    else --如果总记录条数不能被页大小整除 
        set @pageCount = @recordCount / @pageSize + 1 --总页数就等于总记录条数除以页大小加1 
    
    set @sqlSelect = 
    N'select '+@columns+' from ( 
    select row_number() over (order by ' 
    +@orderColumnName+' '+@order 
    +') as tempid,* from ' 
    +@tableName+' where '+ @where 
    +') as tempTableName where tempid between ' 
    +str((@pageIndex - 1)*@pageSize + 1 ) 
    +' and '+str( @pageIndex * @pageSize) 
    exec (@sqlSelect) --执行动态Sql 
end 

--以下是调用示例 
declare @pageCount int 
exec commonPagination 
'job_id,job_desc','jobs','job_id', 
'asc','1=1',2,2,@pageCount output 
select '总页数为:' + str(@pageCount)

 

相关实践学习
使用交互方式创建数据表
本次实验主要介绍如何在RDS-SQLServer数据库中使用交互方式创建数据表。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3月前
|
SQL 存储 数据库
盘点现在用的SqlServer 5种分页方式和拉姆达表达式分页,进来看看吧。
盘点现在用的SqlServer 5种分页方式和拉姆达表达式分页,进来看看吧。
|
3月前
|
存储
【干货】SqlServer 总结几种存储过程分页的使用
【干货】SqlServer 总结几种存储过程分页的使用
|
关系型数据库 MySQL
mysql分页原理和sqlserver里面序列的用法
mysql分页原理和sqlserver里面序列的用法
120 0
|
SQL Oracle 关系型数据库
Oracle、DB2、SQLSERVER、Mysql、Access分页SQL语句
最近把平时在项目中常用到的数据库分页sql总结了下。大家可以贴出分页更高效的sql语句。
127 0
|
Oracle Java 关系型数据库
mybatis下SqlServer的分页的最优解
mybatis下SqlServer的分页的最优解
推荐文章
更多