优先选择之sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)这个速度更快
来源:互联网 发布:西西软件乐园 编辑:程序博客网 时间:2024/05/14 20:35
CREATE PROC test_2_sp_PageView@tbname sysname, --要分页显示的表名@FieldKey sysname, --用于定位记录的主键(惟一键)字段,只能是单个字段@PageCurrent int=1, --要显示的页码@PageSize int=10, --每页的大小(记录数)@FieldShow nvarchar(1000)='', --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段@FieldOrder nvarchar(1000)='', --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC @Where nvarchar(1000)='', --查询条件@PageCount int OUTPUT --总页数ASDECLARE @sql nvarchar(4000)SET NOCOUNT ON--检查对象是否有效IF OBJECT_ID(@tbname) IS NULLBEGIN RAISERROR(N'对象"%s"不存在',1,16,@tbname) RETURNENDIF OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTable')=0 AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsView')=0 AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTableFunction')=0BEGIN RAISERROR(N'"%s"不是表、视图或者表值函数',1,16,@tbname) RETURNEND--分页字段检查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 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--计算分页显示的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)ELSEBEGIN SELECT @PageCurrent=@TopN1, @sql=N'SELECT @n=@n-1,@s=CASE WHEN @n<'+@TopN +N' THEN @s+N'',''+QUOTENAME(RTRIM(CAST('+@FieldKey +N' as varchar(8000))),N'''''''') ELSE N'''' END FROM '+@tbname +N' '+@Where +N' '+@FieldOrder SET ROWCOUNT @PageCurrent EXEC sp_executesql @sql, N'@n int,@s nvarchar(4000) OUTPUT', @PageCurrent,@sql OUTPUT SET ROWCOUNT 0 IF @sql=N'' EXEC(N'SELECT TOP 0' +N' '+@FieldShow +N' FROM '+@tbname) ELSE BEGIN SET @sql=STUFF(@sql,1,1,N'') --执行查询 EXEC(N'SELECT TOP '+@TopN +N' '+@FieldShow +N' FROM '+@tbname +N' WHERE '+@FieldKey +N' IN('+@sql +N') '+@FieldOrder) ENDEND
- 优先选择之sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)这个速度更快
- sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)
- sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)最录活,性能差
- sql server 2005 可用的已测试的20101009修改的分页存储过程
- 原创:SQL Server的通用分页存储过程,未使用游标,速度更快!
- 通用分页存储过程--可用于复合主键盘(字段)排序
- SQL Server可按任意字段排序的分页存储过程(不用临时表的方法)
- SQL超快的分页存储过程
- 很强的分页存储过程,速度超快!
- 很强的分页存储过程,速度超快!
- 超强的分页存储过程 可用来各种查询
- SQL Server 开发之 分页存储过程
- 可用。存储分页
- 快的存储过程分页
- SQL Server 存储过程的分页
- SQL Server 存储过程的分页
- SQL Server 存储过程的分页
- SQL Server 存储过程的分页
- android 源码编译
- 测试的价值不仅仅是找Bug (转贴)
- Javascript刷新页的方法汇总
- JNI
- oracle中distinct多个字段
- 优先选择之sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)这个速度更快
- 如何使用 rdesktop 的 seamlessrdp 模式(转)
- 页面底部 滚动新闻
- fedora13 启动出了问题:unexpected inconsistency;RUN fsck MANUALLY
- jquery性能优化
- 建立子窗体时出现错误“cannot make a visible window modal”
- U盘 病毒
- zoj 3410 Layton's Escape
- 学习windows