主页 > 知识库 > sqlserver 通用分页存储过程

sqlserver 通用分页存储过程

热门标签:电销机器人公司 需要哪些牌照 菏泽语音电销机器人加盟公司 长沙智能外呼系统 地图标注牌 广东防封卡外呼系统原理是什么 外呼系统改进 知名电销机器人价格 湖南电脑外呼系统平台 分享百度地图标注多个位置
复制代码 代码如下:

create proc 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 output --总页数,输出参数
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
go
--以下是调用示例
use pubs
go
declare @pageCount int
exec commonPagination
'job_id,job_desc','jobs','job_id',
'asc','1=1',2,2,@pageCount output
select '总页数为:' + str(@pageCount)
您可能感兴趣的文章:
  • 高效的SQLSERVER分页查询(推荐)
  • 真正高效的SQLSERVER分页查询(多种方案)
  • 分页 SQLServer存储过程
  • sqlserver分页的两种写法分别介绍
  • sqlserver 三种分页方式性能比较[图文]
  • 基于sqlserver的四种分页方式总结
  • sqlserver分页查询处理方法小结
  • sqlserver 存储过程分页代码
  • SQL server分页的4种方法示例(很全面)

标签:泉州 呼和浩特 商洛 天水 珠海 西宁 美容院 福建

巨人网络通讯声明:本文标题《sqlserver 通用分页存储过程》,本文关键词  sqlserver,通用,分页,存储,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《sqlserver 通用分页存储过程》相关的同类信息!
  • 本页收集关于sqlserver 通用分页存储过程的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章