热门标签 | 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
 

推荐阅读
  • 开发笔记:Python:GUI之tkinter学习笔记1控件的介绍及使用
    开发笔记:Python:GUI之tkinter学习笔记1控件的介绍及使用 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文详细介绍 Go+ 编程语言中的上下文处理机制,涵盖其基本概念、关键方法及应用场景。Go+ 是一门结合了 Go 的高效工程开发特性和 Python 数据科学功能的编程语言。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • ML学习笔记20210824分类算法模型选择与调优
    3.模型选择和调优3.1交叉验证定义目的为了让模型得精度更加可信3.2超参数搜索GridSearch对K值进行选择。k[1,2,3,4,5,6]循环遍历搜索。API参数1& ... [详细]
  • 本文介绍如何在Windows Forms应用程序中使用C#实现DataGridView的多列排序功能,包括升序和降序排序。 ... [详细]
  • 本文详细介绍了如何在Android应用中使用GridView组件以网格形式展示数据(如文本和图像)。通过行列布局,实现类似矩阵的数据展示效果。 ... [详细]
  • Python 中使用 Pyecharts 绘制雷达图详解
    本文将详细介绍如何在 Python 环境中利用 Pyecharts 库来创建美观且功能丰富的雷达图。适合需要图形化展示多维度数据的开发者和研究人员。 ... [详细]
  • 本文介绍了如何在VB.NET版机房收费系统中实现数据从DataGridView导出至Excel的功能,包括环境配置、代码实现及常见问题解决方法。 ... [详细]
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社区 版权所有