SQL 分页存储过程
2011-09-03 15:12
405 查看
CREATE PROC procPaging @tbname sysname, --要分页显示的表名 @FieldKey nvarchar(1000), --用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段 @PageCurrent int=1, --要显示的页码 @PageSize int=10, --每页的大小(记录数) @FieldShow nvarchar(1000)='', --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段 @FieldOrder nvarchar(1000)='', --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC用于指定排序顺序 @Where nvarchar(1000)='', --查询条件 @PageCount int OUTPUT, --总页数 @recordcount int OUTPUT --总记录数 AS SET NOCOUNT ON --检查对象是否有效 IF OBJECT_ID(@tbname) IS NULL BEGIN RAISERROR(N'对象"%s"不存在',1,16,@tbname) RETURN END IF OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTable')=0 AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsView')=0 AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTableFunction')=0 BEGIN RAISERROR(N'"%s"不是表、视图或者表值函数',1,16,@tbname) RETURN END --分页字段检查 IF ISNULL(@FieldKey,N'')='' BEGIN RAISERROR(N'分页处理需要主键(或者惟一键)',1,16) RETURN END --其他参数检查及规范 IF ISNULL(@PageCurrent,0)<1 SET @PageCurrent=1 IF ISNULL(@PageSize,0)<1 SET @PageSize=10 IF ISNULL(@FieldShow,N'')=N'' SET @FieldShow=N'*' IF ISNULL(@FieldOrder,N'')=N'' SET @FieldOrder=N'' ELSE SET @FieldOrder=N'ORDER BY '+LTRIM(@FieldOrder) IF ISNULL(@Where,N'')=N'' SET @Where=N'' ELSE SET @Where=N'WHERE ('+@Where+N')' --如果@PageCount为NULL值,则计算总页数(这样设计可以只在第一次计算总页数,以后调用时,把总页数传回给存储过程,避免再次计算总页数,对于不想计算总页数的处理而言,可以给@PageCount赋值) IF @PageCount is null BEGIN DECLARE @sql nvarchar(4000) SET @sql=N'SELECT @PageCount=COUNT(*)' +N' FROM '+@tbname +N' '+@Where EXEC sp_executesql @sql,N'@PageCount int OUTPUT',@PageCount OUTPUT SET @PageCount=(@PageCount+@PageSize-1)/@PageSize END IF @recordcount is null BEGIN DECLARE @sqlrecord nvarchar(4000) SET @sqlrecord=N'SELECT @recordcount=COUNT(*)' +N' FROM '+@tbname +N' '+@Where EXEC sp_executesql @sqlrecord,N'@recordcount int OUTPUT',@recordcount OUTPUT END --计算分页显示的TOPN值 DECLARE @TopN varchar(20),@TopN1 varchar(20) SELECT @TopN=@PageSize, @TopN1=@PageCurrent*@PageSize --第一页直接显示 IF @PageCurrent=1 EXEC(N'SELECT TOP '+@TopN +N' '+@FieldShow +N' FROM '+@tbname +N' '+@Where +N' '+@FieldOrder) ELSE BEGIN --生成主键(惟一键)处理条件 DECLARE @Where1 nvarchar(4000),@s nvarchar(1000) SELECT @Where1=N'',@s=@FieldKey WHILE CHARINDEX(N',',@s)>0 SELECT @s=STUFF(@s,1,CHARINDEX(N',',@s),N''), @Where1=@Where1 +N' AND a.'+LEFT(@s,CHARINDEX(N',',@s)-1) +N'='+LEFT(@s,CHARINDEX(N',',@s)-1) SELECT @Where1=STUFF(@Where1+N' AND a.'+@s+N'='+@s,1,5,N''), @TopN=@TopN1-@PageSize --执行查询 EXEC(N'SET ROWCOUNT '+@TopN1 +N' SELECT '+@FieldKey +N' INTO # FROM '+@tbname +N' '+@Where +N' '+@FieldOrder +N' SET ROWCOUNT '+@TopN +N' DELETE FROM #' +N' SELECT '+@FieldShow +N' FROM '+@tbname +N' a WHERE EXISTS(SELECT * FROM # WHERE '+@Where1 +N') '+@FieldOrder) END
相关文章推荐
- SQL 单表分页存储过程和单表多字段排序和任意字段分页存储过程
- 分页查询存储过程sql语句
- c#学习之-c#通过sql存储过程实现分页
- SQL 2005 ,sql 2008. 分页存储过程
- 【SQL】存储过程分页代码详解
- sql分页存储过程
- MS SQL Server 分页存储过程
- Sql 分页存储过程
- (转)拼sql存储过程分页
- sql分页存储过程
- 百万级SQL分页存储过程
- 数据库开发必看 -- 用索引优化SQL,开发优秀的分页存储过程(一)
- 通过存储过程进行分页查询的SQL示例
- 实现SQL分页的存储过程代码
- 针对sql 2005优化的高性能分页存储过程
- SQL之通用查询分页存储过程
- Delphi调用SQL分页存储过程实例
- 存储过程分页,以及动态sql(Sql server)
- SQL分页存储过程