MS SQLSERVER通用存储过程分页

最近在面试的时候,遇到个奇葩的秃顶老头面试官。

问:写过存储过程分页吗?

答:没写过,但是我知道分页存储的原理,我自己也写过,只是在工作中没写过。

问:那你这么多年工作中就没写过吗?

答:的确没写过,因为项目数据量都特别小。

然后,这奇葩就起身就要走人了,连个招呼都没有。想我面试了这么多公司,这种奇葩面试官,还是头回见到,一点职业素质,礼貌都木有。气死我了!

明天要去入职新公司了,今天闲来无事,试着写了写这个存储过程分页。只在SQLSERVER2008上测试过,不过我想,2000以上版本应该都会支持的吧。

废话到此,上代码。

if (object_id(‘Proc_Paging‘, ‘P‘) is not null)
    drop proc Proc_Paging
go
create procedure Proc_Paging
(
	@TableName varchar(20),--表名
	@PageIndex int=0,--起始页索引,从0开始
	@PageSize varchar(1000)=‘10‘,--默认每页显示的数量,默认每页显示10条记录
	@Params varchar(100)=‘*‘,--分页结果中显示的字段,默认显示全部的字段
	@ID varchar(20)=‘ID‘,--数据编号排序字段,默认为ID
	@OrderByID varchar(20)=‘asc‘,--数据编号排序方式,默认为正序排序
	@StrWhere varchar(100),--分页数据的查询条件,必须以where开头
	@StrWhere2 varchar(100),--已经分页的数据的查询条件,不能以where开头
	@OrderBy varchar(100)=‘ID asc‘--数据排序方式
)
as
declare @Sql varchar(8000),@PageStartNum varchar(1000),@PageEndNum varchar(1000),@Sql2 varchar(1000),@Sql3 varchar(1000)
--1.获取指定页数据
set @PageStartNum=(@PageIndex)*(@PageSize)--起始数据编号
set @PageEndNum=(@PageIndex+1)*(@PageSize)--截止数据编号
set @Sql=‘select row_number() over(order by ‘[email protected]+‘ ‘[email protected]+‘) Num,‘[email protected]+‘ ‘+
‘into #temp ‘+
‘from ‘[email protected]+‘ ‘[email protected]+‘‘+
‘select * from #temp where Num between ‘+
‘‘+(@PageStartNum)+‘ and ‘+(@PageEndNum)+‘ ‘[email protected]+‘ order by ‘[email protected]+‘ ‘
exec(@Sql)
--print @Sql
--2.获取总记录数
set @Sql2=‘select count(1) from ‘[email protected]+‘‘
exec(@Sql2)
--print @Sql2
--3.获取分页总数
set @Sql3=‘select ceiling(count(1)*1.0/(‘[email protected]+‘)) from ‘[email protected]+‘‘
exec(@Sql3)
--print @Sql3
go
--测试代码
exec Proc_Paging ‘Customers‘,2,10,‘CustomerID,CompanyName,Address,City,PostalCode‘,‘CustomerID‘,‘asc‘,‘where PostalCode>‘‘1000‘‘ ‘,‘and Num>1 ‘,‘Num asc‘
go

下面是运行结果截图。

执行结果:

生成的sql语句:

大神,勿喷;菜鸟,轻拍。谢谢!

时间: 2024-11-07 02:13:26

MS SQLSERVER通用存储过程分页的相关文章

改良版的SQL Service 通用存储过程分页

上次写了通用存储过程.感觉还是有很大的BUG.就是条件不能参数画化.这个BUG可以说是致命的.但是我一直想在用什么方法能解决这个东西.其实我只是想写少量的代码来做更多的事情.我想能不能传集合给存储过程但是好像这个是行不通没办法只能写死. 上代码吧 IF (SELECT COUNT(*) FROM sysobjects s WHERE s.[type]='P' AND s.name='SP_PAGE_PRACTICAL')>0 DROP PROC SP_PAGE_PRACTICAL; GO CRE

如此高效通用的分页存储过程是带有sql注入漏洞的

原文:如此高效通用的分页存储过程是带有sql注入漏洞的 在google中搜索“分页存储过程”会出来好多结果,是大家常用的分页存储过程,今天我却要说它是有漏洞的,而且漏洞无法通过修改存储过程进行补救,如果你觉得我错了,请读下去也许你会改变看法. 通常大家都会认为存储过程可以避免sql注入的漏洞,这适用于一般的存储过程,而对于通用分页存储过程是不适合的,请看下面的代码和分析! 一般的通用的分页存储过程代码如下: 通用分页存储过程CREATE PROCEDURE pagination@tblName 

SQL存储过程分页(通用的拼接SQL语句思路实现)

多表通用的SQL存储过程分页 USE [EmailCenter] GO /****** Object: StoredProcedure [dbo].[Common_PageList] Script Date: 2016/2/29 11:00:19 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROC [dbo].[Common_PageList] ( @tab nvarchar(200),---表名 @strFl

SqlServer 存储过程分页

一:存储过程实现分页 例子:查询楼盘列表 ALTER procedure [dbo].[BM_GetBlockList] @pageIndex int,-------页码数 @PageSize int,---------展示的条数 @cityId int as declare @sql nvarchar(max) , @sql2 nvarchar(max) set @sql=' from AgentRecmd_Block ab LEFT JOIN BASE_BLOCK block on ab.B

sqlserver 存储过程分页管理

-- =============================================-- Author:  <Author:刘畅>-- Create date: <Create Date:2014-07-31>-- Description: <Description:sqlserver 2008 R2 数据库分页存储过程> -- =============================================CREATE PROCEDURE pr_

【原创】10万条数据采用存储过程分页实现(Mvc+Dapper+存储过程)

有时候大数据量进行查询操作的时候,查询速度很大强度上可以影响用户体验,因此自己简单写了一个demo,简单总结记录一下: 技术:Mvc4+Dapper+Dapper扩展+Sqlserver 目前主要实现了两种分页:一种采用 PagedList.Mvc 实现的分页 两外一种采用 ajax异步加载分页 采用比较常用的jquery.pagination 分页插件. 功能相对比较简单仅供学习交流. 通用存储过程 1 USE [MvcProcPageDB] 2 GO 3 4 /****** Object:

asp.net利用存储过程分页代码

-最通用的分页存储过程 -- 获取指定页的数据 CREATE PROCEDURE Pagination @tblName varchar(255), -- 表名 @strGetFields varchar(1000) = '*', -- 需要返回的列 @fldName varchar(255)='', -- 排序的字段名 @PageSize int = 10, -- 页尺寸 @PageIndex int = 1, -- 页码 @doCount bit = 0, -- 返回记录总数, 非 0 值则

分享一个通用的分页SQL

又很久没写博客,今天记录一个SQLserver通用分页存储过程(适用于SqlServer2000及以上版本) 1.支持连表 2.支持条件查询 USE [MYDB] GO /****** Object:  StoredProcedure [dbo].[SP_CommonPage] SET QUOTED_IDENTIFIER ON GO ------------------------------------ --用途:分页存储过程(对有主键的表效率极高) --说明: ---------------

存储过程分页 Ado.Net分页 EF分页 满足90%以上

存储过程分页: 1 create proc PR_PagerDataByTop 2 @pageIndex int, 3 @pageSize int, 4 @count int out 5 as 6 select top(@pageSize) * from dbo.userInfo where ID not in 7 ( 8 select top((@pageIndex-1)*@pageSize) ID from dbo.userInfo 9 ) 10 set @count = (select C