如何实现在SQLsever存储过程分页查询
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇文章给大家分享的是有关如何实现在SQLsever存储过程分页查询,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用存储过程实现分页查
千家信息网最后更新 2025年11月07日如何实现在SQLsever存储过程分页查询
本篇文章给大家分享的是有关如何实现在SQLsever存储过程分页查询,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
使用存储过程实现分页查询,SQL语句如下:
USE [DatebaseName] --数据库名GO/****** Object: StoredProcedure [dbo].[Pagination] Script Date: 03/30/2019 10:36:52 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCreate PROCEDURE [dbo].[Pagination]( @SqlTable varchar(1000),--要查询的表或视图,也可以一句sql语句 @SqlPK varchar(50),--主键 @SqlField varchar(1000),--查询的字段 @SqlWhere varchar(1000)='', --查询条件 @SqlOrder varchar(200),--排序 @PageSize int=20,--每页的记录数 @PageIndex int=1, --第几页,默认第一页 @IsCount bit, --是否获取记录数 @RecordCount int=0 output)ASSET NOCOUNT ONDECLARE @PageLowerBound intDECLARE @PageUpperBound intDECLARE @sqlstr nvarchar(2000)--获取记录数IF @IsCount=1BEGIN SET @sqlstr=N'select @sCount=count(1) FROM '+@SqlTable+' WHERE 1=1 '+@SqlWhere Exec sp_executesql @sqlstr,N'@sCount int outPut',@RecordCount OUTPUTENDSET @PageLowerBound=(@PageIndex-1)*@PageSizeSET @PageUpperBound=@PageLowerBound+@PageSizeCREATE TABLE #pageindex(id int identity(1,1) not null,nid varchar(100))SET rowcount @PageUpperBound SET @sqlstr=N'insert into #pageindex(nid) select '+@SqlPK+' from '+@SqlTable+' where 1=1 '+@SqlWhere+' '+@SqlOrderExec sp_executesql @sqlstrSET @sqlstr='select '+@SqlField+' FROM '+ @SqlTable +' inner join #pageindex p on '+@SqlPK+'=p.nid and (p.id>'+STR(@PageLowerBound)+') and (p.id<='+STR(@PageUpperBound)+')' +' '+@SqlOrderExec sp_executesql @sqlstrSET NOCOUNT OFFDROP TABLE #pageindex
但是如果你有一些奇怪的需求,比如删除当前页数据之后不重新返回第一页,然后继续请求下一页,这时会出现有一下数据被跳过查询
解决方案如下:
USE [DatebaseName]GO/****** Object: StoredProcedure [dbo].[Pagination] Script Date: 03/30/2019 14:41:39 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCREATE PROCEDURE [dbo].[PaginationSkip]( @SqlTable varchar(1000),--要查询的表或视图,也可以一句sql语句 @SqlPK varchar(50),--主键 @SqlField varchar(1000),--查询的字段 @SqlWhere varchar(1000)='', --查询条件 @SqlOrder varchar(200),--排序 @PageSize int=20,--每页的记录数 @PageIndex int=1, --第几页,默认第一页 @IsCount bit, --是否获取记录数 @RecordCount int=0 output, @Skip int=0 --跳过记录数)ASSET NOCOUNT ONDECLARE @PageLowerBound intDECLARE @PageUpperBound intDECLARE @sqlstr nvarchar(2000)--获取记录数IF @IsCount=1BEGIN SET @sqlstr=N'select @sCount=count(1) FROM '+@SqlTable+' WHERE 1=1 '+@SqlWhere Exec sp_executesql @sqlstr,N'@sCount int outPut',@RecordCount OUTPUTENDSET @PageLowerBound=(@PageIndex-1)*@PageSize-@Skip --减去删除的条数,以适应需求SET @PageUpperBound=@PageLowerBound+@PageSize-@Skip CREATE TABLE #pageindex(id int identity(1,1) not null,nid varchar(100))SET rowcount @PageUpperBound SET @sqlstr=N'insert into #pageindex(nid) select '+@SqlPK+' from '+@SqlTable+' where 1=1 '+@SqlWhere+' '+@SqlOrderExec sp_executesql @sqlstrSET @sqlstr='select '+@SqlField+' FROM '+ @SqlTable +' inner join #pageindex p on '+@SqlPK+'=p.nid and (p.id>'+STR(@PageLowerBound)+') and (p.id<='+STR(@PageUpperBound)+')' +' '+@SqlOrderExec sp_executesql @sqlstrSET NOCOUNT OFFDROP TABLE #pageindexGO
添加了一个 Skip 参数,来指示需要往前推进几条数据,这个参数就是你在请求之前删除的条数
以上就是如何实现在SQLsever存储过程分页查询,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。
查询
数据
过程
存储
语句
参数
字段
就是
更多
条件
知识
篇文章
视图
需求
排序
实用
工作会
指示
数据库
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全化和信息化是
网络安全法第二章解读
清华同方数据库技术学校
传奇手游最安全的服务器
云南ipfs服务器配置虚拟主机
实验一 数据库及表的建立
福建展览展厅中控服务器
云服务器域名怎么注册
为什么打幻塔总是无法连接服务器
数据库 性别字段
物联网跟计算机网络技术一样吗
北京大学临床数据库
汉阳专业的软件开发团队
威廉公司英超赔率大数据库
湖南服务器电源售价
部队手机网络安全宣传海报
互联网科技有限公司政策支持
钰宇网络技术有限公司
上市公司数据万得数据库
永康 软件开发
崇明区通信网络技术结构设计
关系数据库规则
ice服务器管理员
软件开发费用增长
软件开发资格条件
重庆友信网络技术有限公司
数据库将电脑跑崩溃了怎么停止
表单返回选中行的数据库
网络安全工程师需要加班吗
国企网络安全工程招聘信息