SQL Server 2005 分页存储过程

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:

支持:多表连接查询、Group by分组查询等。(多表连接查询时请指定字段,不要用SELECT *)
返回为一结果集,有一个输出参数为记录总数,配合AspNetPager控件使用绝配。
转载请注明出处,欢迎讨论Pk。

CREATE   PROCEDURE  web_pager (
    
@rowsTotal   INT  OUTPUT,             -- 输出记录总数
     @tableName   VARCHAR ( 800 ),         -- 表名
     @fieldName   VARCHAR ( 800 ),         -- 查询字段
     @keyName   VARCHAR ( 200 ),             -- 索引字段
     @pageSize   INT ,                     -- 每页记录数
     @pageNow   INT ,                     -- 当前页
     @stringOrder   VARCHAR ( 200 ),         -- 排序条件
     @stringWhere   VARCHAR ( 800 )         -- WHERE条件
)
AS
BEGIN
     
DECLARE   @beginRow   INT
     
DECLARE   @endRow   INT
     
DECLARE   @tempLimit   VARCHAR ( 200 )
     
DECLARE   @tempCount   NVARCHAR ( 1000 )
     
DECLARE   @tempMain   VARCHAR ( 1000 )

     
SET   @beginRow   =  ( @pageNow   -   1 *   @pageSize      +   1
     
SET   @endRow   =   @pageNow   *   @pageSize
     
SET   @tempLimit   =   ' rows BETWEEN  '   +   CAST ( @beginRow   AS   VARCHAR + '  AND  ' + CAST ( @endRow   AS   VARCHAR )
     
     
-- 输出参数为总记录数
      SET   @tempCount   =   ' SELECT @rowsTotal = COUNT(*) FROM (SELECT  ' + @keyName + '  FROM  ' + @tableName + '  WHERE  ' + @stringWhere + ' ) AS my_temp '
     
EXECUTE  sp_executesql  @tempCount ,N ' @rowsTotal INT OUTPUT ' , @rowsTotal  OUTPUT
       
     
-- 主查询返回结果集
      SET   @tempMain   =   ' SELECT * FROM (SELECT ROW_NUMBER() OVER ( ' + @stringOrder + ' ) AS rows , ' + @fieldName + '  FROM  ' + @tableName + '  WHERE  ' + @stringWhere + ' ) AS main_temp WHERE  ' + @tempLimit
     
EXECUTE  ( @tempMain )
END
本文转自chy710博客园博客,原文链接:http://www.cnblogs.com/chy710/archive/2008/05/15/1198202.html ,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
2天前
|
存储 SQL 数据库
数据库sql语句-----游标和存储过程
数据库sql语句-----游标和存储过程
14 1
|
21小时前
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用合集之当 SQL Server 源数据库中的数据更新后,CDC 吐出的操作(op)是怎样的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
11 0
|
2天前
|
存储 数据库
sqlserver------数据库的存储过程(练习)
sqlserver------数据库的存储过程(练习)
8 1
|
2天前
|
SQL XML Linux
SQL Server的版本
【5月更文挑战第14天】SQL Server的版本
18 3
|
2天前
|
SQL 关系型数据库 数据管理
Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
【5月更文挑战第14天】Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
13 2
|
2天前
|
SQL 存储 数据库连接
LabVIEW与SQL Server 2919 Express通讯
LabVIEW与SQL Server 2919 Express通讯
|
2天前
|
SQL Windows
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
14 4
|
2天前
|
SQL 数据可视化 Oracle
这篇文章教会你:从 SQL Server 移植到 DM(上)
这篇文章教会你:从 SQL Server 移植到 DM(上)
|
2天前
|
SQL 关系型数据库 数据库
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
|
2天前
|
SQL 存储 网络协议
SQL Server详细使用教程
SQL Server详细使用教程
31 2