Code
Create PROCEDURE SP_Pagination
/*
***************************************************************
** 千万数量级分页存储过程 **
***************************************************************
参数说明:
1.Tables :表名称,视图
2.PrimaryKey :主关键字
3.Sort :排序语句,不带Order By 比如:NewsID Desc,OrderRows Asc
4.CurrentPage :当前页码
5.PageSize :分页尺寸
6.Filter :过滤语句,不带Where 
7.Group :Group语句,不带Group By
效果演示:http://www.cn5135.com/_App/Enterprise/QueryResult.aspx
***************************************************************/
(
@Tables varchar(1000),
@PrimaryKey varchar(100),
@Sort varchar(200) = NULL,
@CurrentPage int = 1,
@PageSize int = 10,
@Fields varchar(1000) = '*',
@Filter varchar(1000) = NULL,
@Group varchar(1000) = NULL
)
AS
/*默认排序*/
IF @Sort IS NULL or @Sort = ''
    SET @Sort = @PrimaryKey
DECLARE @SortTable varchar(100)
DECLARE @SortName varchar(100)
DECLARE @strSortColumn varchar(200)
DECLARE @operator char(2)
DECLARE @type varchar(100)
DECLARE @prec int

/*设定排序语句.*/
IF CHARINDEX('DESC',@Sort)>0
    BEGIN
        SET @strSortColumn = REPLACE(@Sort, 'DESC', '')
        SET @operator = '<='
    END
ELSE
    BEGIN
        IF CHARINDEX('ASC', @Sort) = 0
            SET @strSortColumn = REPLACE(@Sort, 'ASC', '')
            SET @operator = '>='
    END

IF CHARINDEX('.', @strSortColumn) > 0
    BEGIN
        SET @SortTable = SUBSTRING(@strSortColumn, 0, CHARINDEX('.',@strSortColumn))
        SET @SortName = SUBSTRING(@strSortColumn, CHARINDEX('.',@strSortColumn) + 1, LEN(@strSortColumn))
    END
ELSE
    BEGIN
        SET @SortTable = @Tables
        SET @SortName = @strSortColumn
    END

Select @type=t.name, @prec=c.prec 
FROM sysobjects o JOIN syscolumns c on o.id=c.id JOIN systypes t on c.xusertype=t.xusertype
Where o.name = @SortTable AND c.name = @SortName

IF CHARINDEX('char', @type) > 0
    SET @type = @type + '(' + CAST(@prec AS varchar) + ')'

DECLARE @strPageSize varchar(50)
DECLARE @strStartRow varchar(50)
DECLARE @strFilter varchar(1000)
DECLARE @strSimpleFilter varchar(1000)
DECLARE @strGroup varchar(1000)

/*默认当前页*/
IF @CurrentPage < 1
    SET @CurrentPage = 1

/*设置分页参数.*/
SET @strPageSize = CAST(@PageSize AS varchar(50))
SET @strStartRow = CAST(((@CurrentPage - 1)*@PageSize + 1) AS varchar(50))
/*筛选以及分组语句.*/

IF @Filter IS NOT NULL AND @Filter != ''
    BEGIN
        SET @strFilter = ' Where ' + @Filter + ' '
        SET @strSimpleFilter = ' AND ' + @Filter + ' '
    END
ELSE
    BEGIN
        SET @strSimpleFilter = ''
        SET @strFilter = ''
    END

IF @Group IS NOT NULL AND @Group != ''
    SET @strGroup = ' GROUP BY ' + @Group + ' '
ELSE
    SET @strGroup = ''

/*执行查询语句*/
EXEC('
DECLARE @SortColumn ' + @type + '
SET ROWCOUNT ' + @strStartRow + '
Select @SortColumn=' + @strSortColumn + ' FROM ' + @Tables + @strFilter + ' ' + @strGroup + ' orDER BY ' + @Sort + '
SET ROWCOUNT ' + @strPageSize + '
Select ' + @Fields + ' FROM ' + @Tables + ' Where ' + @strSortColumn + @operator + ' @SortColumn ' + @strSimpleFilter + ' ' + @strGroup + ' orDER BY ' + @Sort + '
')
GO

转载于:https://www.cnblogs.com/loay/archive/2009/03/27/1422839.html

千万数量级分页存储过程[转帖]相关推荐

  1. [分享]千万数量级分页存储过程(效果演示)

    http://blog.csdn.net/evafly920/archive/2006/03/03/614813.aspx [分享]千万数量级分页存储过程(效果演示) 效果演示:http://www. ...

  2. 千万数量级分页存储过程

    ALTER PROCEDURE[dbo].[UP_DividePage] /* ************************************************************ ...

  3. 千万级分页存储过程结合Repeater+Aspnetpager7.2实现

    存储过程  1set ANSI_NULLS ON  2set QUOTED_IDENTIFIER ON  3go  4  5--参数说明  6----------------------------- ...

  4. oracle千万级分页优化,oracle千万级数据分页存储过程优化

    随着数据量的增加,Oracle数据库分页存储过程(使用rownum分页)查询性能越来越差,查询时间也越来越长,于是优化势在必行,结合用户一般使用特点(一般看前几页的较多),于是以此为切入点优化原先的存 ...

  5. SQL Server分页存储过程实践(图解)

    下面来对SQL Server分页存储过程进行一下实做.图解成功的各个步骤. 一 找到大数据量的示例表 分页都是针对大记录数的表:反之有大记录数的表,可能就需要分页.例如银行用户表,就会上千万.下面先做 ...

  6. [百万级]通用存储过程.分页存储过程

    /*  名称:spAll_ReturnRows  输入:  输出:  调用:   EXEC spAll_ReturnRows 'SELECT  * FROM 表名', 页号, 返回记录数, '主键', ...

  7. 动软 mysql 分页_动软.NET 分页存储过程UP_GetRecordByPage

    1, ------------------------------------ --用途:支持任意排序的分页存储过程 --说明: ----------------------------------- ...

  8. 通用分页存储过程(转自邹建)

    --TOP n 实现的通用分页存储过程(转自邹建) CREATE PROC sp_PageView @tbname     sysname,               --要分页显示的表名 @Fie ...

  9. oracle存储过程 多条件,Oracle多条件查询实际分页存储过程实操

    以下的文章主要是介绍Oracle多条件查询分页存储过程,以下就是Oracle多条件查询分页存储过程具体方案的描述,希望在你今后的学习中会有所帮助.将业务逻辑放到Oracle中使得后台代码很精简,Ora ...

最新文章

  1. 牛顿法, Jacobian矩阵 和 Hessian矩阵
  2. invalid use of null value
  3. win7系统怎么拷贝到u盘_Win7系统电脑无法识别U盘启动盘怎么办?
  4. 手机相机里面的m_2020拍立得相机选购指南 富士乐魔徕卡推荐 总有一款适合你...
  5. spring教程笔记6
  6. php api接口怎么写,php如何写api接口?
  7. 单片机零基础入门(8-5)模块化编程
  8. 如何避免PayPal、Fb、谷歌账户被封,又如何解封?
  9. C/C++基于朋友圈的商品推荐系统
  10. 红旗linux怎么升级,[原]使用yum更新红旗Linux
  11. Java中对excle的一些操作
  12. CDN服务及如何获取CDN服务背后的真实IP
  13. 【JavaScript】JS校验MAC地址
  14. PHP 简单案例[5]
  15. GPT(4kb硬盘) 单硬盘装变色龙、GA-H61MA-D2V、ALC887-VD、HD6570成功驱动经验(转)
  16. 微软杀毒软件Forefront技术不过关
  17. 沁园春.雪输出诗句代码
  18. 2021-08-26某宝补蛋需要注意什么?
  19. 不想努力怎么办,马斯克脑机接口,BrainOS都能帮忙
  20. 笔记-常见考点-事业环境因素包括(但不限于)

热门文章

  1. 猫哥教你写爬虫 037--爬虫-宝宝要听歌
  2. 机器学习 线性回归算法_探索机器学习算法简单线性回归
  3. 【01】什么是 APP?移动 APP 有几种类型?
  4. 韶音骨传导耳机怎么样?南卡旗舰和韶音旗舰横评对比,区别在这些方面
  5. 申宝理财-指数全天探底回升
  6. WHQL认证如何给驱动程序做数字签名
  7. vue常见面试题(附带答案)超实用!!建议收藏!!
  8. C++常见面试题总结
  9. [转载] 华中科技大学学生违纪处分条例
  10. STM32步进电机S型加减速算法