热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

通用分页存储过程返回总记录数

****************************************************************

 

***************************************************************
** 千万数量级分页存储过程,配合EXTJS中的GridPanel分页 **
***************************************************************
 
参数说明:
1.@tbName :表名称,视图,不带dbo.
2.@pkFiled :主关键字
3.@sortExp :排序语句,不带Order By 比如:NewsID Desc,OrderRows Asc (Desc Asc前必须加空格)
4.@start :每页起始行号,第一页是从0开始计算(ExtJs)
5.@limit :每页显示记录数
6.@fields: 字段名
7.@filter :过滤语句,不带Where
8.@group :Group语句,不带Group By
 
返回说明:
返回记录集,table[0]分页后的记录,table[1]当前数据源总记录数
 
测试语句:
Exec [spExtJsPager] @tbName = 'Roles',
      @pkFiled = 'RoleID',
      @start = 3,
      @limit = 3
 
***************************************************************/
ALTER PROCEDURE [dbo].[spExtJsPager]
(
@tbName varchar(1000),
@pkFiled varchar(100),
@sortExp varchar(200) = NULL,
@start int = 0,
@limit int = 20,
@fields varchar(1000) = '*',
@filter varchar(1000) = NULL,
@group varchar(1000) = NULL
)
AS
BEGIN
SET NOCOUNT ON
 
/*默认排序*/
SET @sortExp = RTRIM(LTRIM(@sortExp))
IF @sortExp IS NULL OR @sortExp = ''
   SET @sortExp = @pkFiled
 
DECLARE @sortTable varchar(100)
DECLARE @sortName varchar(100)
DECLARE @SQL varchar(4000)
 
/*设定排序语句.*/
DECLARE @strStartRow varchar(50),@strEndRow varchar(50)
DECLARE @strFilter varchar(1000)
DECLARE @strGroup varchar(1000)
 
/*默认当前页*/
IF @start < 0
   SET @start = 0
 
/*设置分页参数.*/
SET @strStartRow = CAST((@start + 1) AS varchar(50))
SET @strEndRow = CAST((@start + @limit) AS varchar(50))
 
/*筛选以及分组语句.*/
IF @filter IS NOT NULL AND @filter != ''
   BEGIN
    SET @strFilter = ' Where ' + @filter + ' '
   END
ELSE
   BEGIN
    SET @strFilter = ''
   END
 
IF @group IS NOT NULL AND @group != ''
   BEGIN
    SET @strGroup = ' GROUP BY ' + @group + ' '
   END
ELSE
   BEGIN
    SET @strGroup = ''
   END
 
/*执行查询语句*/
SET @SQL ='select * from (
     Select
      ROW_NUMBER() OVER(Order By '+@sortExp+') as SysRowNum,
      ' + @fields + '
     FROM ' + @tbName + @strFilter + @strGroup + '
    ) v
    where SysRowNum between '+@strStartRow+' and '+@strEndRow
 
SET @SQL = @SQL + 'select count('+@pkFiled+') from '+@tbName + @strFilter + @strGroup
EXEC (@SQL)
END
 
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
 

推荐阅读
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • Irish budget airline Ryanair announced plans to significantly increase its route network from Frankfurt Airport, marking a direct challenge to Lufthansa, Germany's leading carrier. ... [详细]
  • 本文介绍了如何通过C#语言调用动态链接库(DLL)中的函数来实现IC卡的基本操作,包括初始化设备、设置密码模式、获取设备状态等,并详细展示了将TextBox中的数据写入IC卡的具体实现方法。 ... [详细]
  • 本文探讨了一种常见的C++面试题目——实现自己的String类。通过此过程,不仅能够检验开发者对C++基础知识的掌握程度,还能加深对其高级特性的理解。文章详细介绍了如何实现基本的功能,如构造函数、析构函数、拷贝构造函数及赋值运算符重载等。 ... [详细]
  • binlog2sql,你该知道的数据恢复工具
    binlog2sql,你该知道的数据恢复工具 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 数据类型--char一、char1.1char占用2个字节char取值范围:【0~65535】char采用unicode编码方式char类型的字面量用单引号括起来char可以存储一 ... [详细]
  • 本文详细介绍了PostgreSQL与MySQL在SQL语法上的主要区别,包括如何使用COALESCE替代IFNULL、金额格式化的方法、别名处理以及日期处理等关键点。 ... [详细]
  • 本文详细介绍了iOS应用的生命周期,包括各个状态及其转换过程中的关键方法调用。 ... [详细]
  • 本文探讨了在SQL Server中处理几何类型列时遇到的INTERSECT操作限制,并提供了解决方案,包括通过转换数据类型和使用额外表结构的方法。 ... [详细]
  • 如何在PHP中安装Xdebug扩展
    本文介绍了如何从PECL下载并编译安装Xdebug扩展,以及如何配置PHP和PHPStorm以启用调试功能。 ... [详细]
author-avatar
millottgerould
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有