SQL SERVER2000分页存储过程
来源:互联网 发布:海澜之家男装淘宝网 编辑:程序博客网 时间:2024/05/22 06:18
1:只能按主键排序
CREATE PROCEDURE [dbo].[proc_pager] @RecordCount int output, @PageCount int output, @PageSize int = 10, -- 页尺寸 @PageIndex int = 1, -- 页码 @TableName nvarchar(255), -- 表名 @FieldsList nvarchar(1000), --列名 @FieldSearchKey nvarchar(1000) = '', -- 查询条件 (注意: 不要加 where) @OrderField nvarchar(255), -- 主键字段名 @OrderType bit = 1 -- 设置排序类型, 非 0 值则降序 AS--declare @startTimer datetimedeclare @strSQL nvarchar(4000) -- 主语句declare @strTmp nvarchar(1010) -- 临时变量declare @strOrder nvarchar(400) -- 排序类型--set @startTimer = getdate()if @OrderType != 0begin set @strTmp = '<(select min' set @strOrder = ' order by [' +@OrderField +'] desc'endelsebegin set @strTmp = '>(select max' set @strOrder = ' order by [' + @OrderField +'] asc'end---------------------------计算总计录数------------------------------------- if @FieldSearchKey IS NOT NULL AND @FieldSearchKey != '' set @strSQL = 'select @RecordCount=count(*) from [' + @TableName + ']'+' where ' + @FieldSearchKey ELSE set @strSQL = 'select @RecordCount=count(*) from [' + @TableName + ']' EXECUTE sp_executesql @strSQL,N'@RecordCount int OUTPUT',@RecordCount OUTPUT set @PageCount=ceiling(@RecordCount*1.0/@PageSize)---------------------------计算总计录数结束----------------------------------if @PageIndex >@PageCountset @PageIndex = @PageCountif @PageCount=0set @PageIndex = 1if @PageIndex<=0set @PageIndex = 1set @strSQL = 'select top ' + cast(@PageSize as nvarchar) + ' ' + @FieldsList + ' from [' + @TableName + '] where [' + @OrderField + ']' + @strTmp + '([' + @OrderField + ']) from (select top ' + cast((@PageIndex-1)*@PageSize as nvarchar) + ' [' + @OrderField + '] from [' + @TableName + ']' + @strOrder + ') as TempTable)' + @strOrderif @FieldSearchKey IS NOT NULL AND @FieldSearchKey != '' set @strSQL = 'select top ' + cast(@PageSize as nvarchar) + ' ' + @FieldsList + ' from [' + @TableName + '] where [' + @OrderField + ']' + @strTmp + '([' + @OrderField + ']) from (select top ' + cast((@PageIndex-1)*@PageSize as nvarchar) + ' [' + @OrderField + '] from [' + @TableName + '] where ' + @FieldSearchKey + ' ' + @strOrder + ') as TempTable) and ' + @FieldSearchKey + ' ' + @strOrderif @PageIndex = 1begin set @strTmp ='' if @FieldSearchKey IS NOT NULL AND @FieldSearchKey != '' set @strTmp = ' where ' + @FieldSearchKey set @strSQL = 'select top ' + cast(@PageSize as nvarchar) + ' ' + @FieldsList + ' from [' + @TableName + ']' + @strTmp + ' ' + @strOrderendselect @RecordCount as RecordCountEXECUTE(@strSQL)GO
2:可按非主键排序(注:主键字段请加上"[ ]")
USE [PowerMS]GO/****** 对象: StoredProcedure [dbo].[proc_pager] 脚本日期: 11/30/2012 12:38:58 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGO--TOP n 实现的通用分页存储过程ALTER PROC [dbo].[proc_pager]@tbname nvarchar(4000), --要分页显示的表名@FieldKey nvarchar(4000), --用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段@PageCurrent int=1, --要显示的页码@PageSize int=10, --每页的大小(记录数)@FieldShow nvarchar(4000)='', --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段@FieldOrder nvarchar(4000)='', --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC用于指定排序顺序 @Where nvarchar(4000)='', --查询条件@PageCount int OUTPUT, --总页数@RecordCount int OUTPUT--总记录数ASSET NOCOUNT ON--分页字段检查IF ISNULL(@FieldKey,N'')=''BEGIN RAISERROR(N'分页处理需要主键(或者惟一键)',1,16) RETURNEND--其他参数检查及规范IF ISNULL(@PageCurrent,0)<1 SET @PageCurrent=1IF ISNULL(@PageSize,0)<1 SET @PageSize=10IF 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 NULLBEGIN 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)/@PageSizeEND--如果@RecordCount为NULL值,则计算总记录数(这样设计可以只在第一次计算总记录数,以后调用时,把总记录数传回给存储过程,避免再次计算总记录数,对于不想计算总记录数的处理而言,可以给@RecordCount赋值)IF @RecordCount IS NULLBEGIN DECLARE @sqlRecordCount nvarchar(4000) SET @sqlRecordCount=N'SELECT @RecordCount=COUNT(*)' +N' FROM '+@tbname +N' '+@Where EXEC sp_executesql @sqlRecordCount,N'@RecordCount int OUTPUT',@RecordCount OUTPUT SET @RecordCount=@RecordCountEND--限制传过来的当前页码数与实际页码总数的值,小于则为起始页,大于则为最后一页if(@PageCurrent>1 AND @PageCurrent>@PageCount)beginset @PageCurrent=@PageCountENDIF(@PageCurrent<=0)BEGINSET @PageCurrent=1END-------------------------------------计算分页显示的TOPN值DECLARE @TopN varchar(20),@TopN1 varchar(20)SELECT @TopN=@PageSize, @TopN1=(@PageCurrent-1)*@PageSize--第一页直接显示IF @PageCurrent=1 EXEC(N'SELECT TOP '+@TopN +N' '+@FieldShow +N' FROM '+@tbname +N' '+@Where +N' '+@FieldOrder)ELSEBEGIN --处理别名 IF @FieldShow=N'*' SET @FieldShow=N'a.*' --生成主键(惟一键)处理条件 DECLARE @Where1 nvarchar(4000),@Where2 nvarchar(4000), @s nvarchar(1000),@Field sysname SELECT @Where1=N'',@Where2=N'',@s=@FieldKey WHILE CHARINDEX(N',',@s)>0 SELECT @Field=LEFT(@s,CHARINDEX(N',',@s)-1), @s=STUFF(@s,1,CHARINDEX(N',',@s),N''), @Where1=@Where1+N' AND a.'+@Field+N'=b.'+@Field, @Where2=@Where2+N' AND b.'+@Field+N' IS NULL', @Where=REPLACE(@Where,@Field,N'a.'+@Field), @FieldOrder=REPLACE(@FieldOrder,@Field,N'a.'+@Field), @FieldShow=REPLACE(@FieldShow,@Field,N'a.'+@Field) SELECT @Where=REPLACE(@Where,@s,N'a.'+@s), @FieldOrder=REPLACE(@FieldOrder,@s,N'a.'+@s), @FieldShow=REPLACE(@FieldShow,@s,N'a.'+@s), @Where1=STUFF(@Where1+N' AND a.'+@s+N'=b.'+@s,1,5,N''), @Where2=CASE WHEN @Where='' THEN N'WHERE (' ELSE @Where+N' AND (' END+N'b.'+@s+N' IS NULL'+@Where2+N')' --执行查询 exec(N'SELECT TOP '+@TopN +N' '+@FieldShow +N' FROM '+@tbname +N' a LEFT JOIN(SELECT TOP '+@TopN1 +N' '+@FieldKey +N' FROM '+@tbname +N' a '+@Where +N' '+@FieldOrder +N')b ON '+@Where1 +N' '+@Where2 +N' '+@FieldOrder)END
- SQL Server2000 分页存储过程
- SQL SERVER2000分页存储过程
- 【转】SQL Server2000 存储过程的分页方案比拼
- JAVA调用sql server2000的分页存储过程
- SQL Server2000 解密存储过程
- SQL Server2000存储过程基础
- delphi调用sql-server2000存储过程
- SQL Server2000 未公开的存储过程
- Servlet调用SQL Server2000存储过程实例
- SQL Server2000存储过程编程经验技巧
- SQL Server2000 未公开的存储过程
- sql server2000找不到存储过程sp_password
- [MSSQL]SQL Server2000存储过程调试
- sql 存储过程分页
- sql 存储过程分页
- sql分页存储过程
- sql分页存储过程
- sql 存储过程分页
- JS :点击按钮table增加一行,删除一行
- android: 静态XML和动态加载XML混合使用,以及重写Layout控件
- VC 中ASCII Unicode GB2312之间的转换
- java例程练习(输出101~200以内所有的质数)
- ubuntu系统中没有/etc/inittab的问题
- SQL SERVER2000分页存储过程
- 第九周任务(五)
- Arctic Network(P2349)
- 第九周 任务1
- 九周任务3
- AOP术语概析
- Android ListView控件基本用法
- 【Android】发送Email(内置Gmail和JavaMail)
- MySQL基本命令