mssql分页存储过程
本文转自百度文库http://wenku.baidu.com/view/8f6ec149fe4733687e21aa72.html
必须有主键
原代码

Codeuse users
go if exists(select name from sysobjects where name='pages' and xtype='p')
drop proc pages
go CREATE PROC pages
@tblName varchar(255), -- 表名
@strGetFields varchar(1000), -- 需要返回的列
@fldName varchar(255), -- 排序的字段名
@PageSize int, -- 多少条/页
@PageIndex int, -- 页码
@doCount bit, -- 返回记录总数, 0不返回,1返回
@OrderType bit, -- 设置排序类型, 0升序,1降序
@strWhere varchar(1500) -- 查询条件 (注意: 不要加 where)
AS declare @strSQL varchar(5000) --主语句
declare @strTmp varchar(150) --临时变量
declare @strOrder varchar(400) --排序类型 --如果@doCount传递过来的不是0,就执行总数统计。
if @doCount != 0
begin
--查询条件为空
set @strSQL = 'select count(*) as Total from ' + @tblName
--查询条件不为空
if @strWhere !=''
set @strSQL = 'select count(*) as Total from ' + @tblName + ' where '+@strWhere
end --以下的所有代码都是@doCount为0的情况:
--如果@OrderType是1,就执行降序,否则为升序!
else
begin
--查询条件为空
set @strTmp = '>(select max'
set @strOrder = ' order by ' + @fldName +' asc'
--查询条件不为空
if @OrderType = 1
begin
set @strTmp = '<(select min'
set @strOrder = ' order by ' + @fldName +' desc'
end --如果是第一页就执行代码,这样会加快执行速度
if @PageIndex = 1
begin
--查询条件为空
set @strSQL='select top '+str(@PageSize)+''+@strGetFields+' from '+@tblName+''+@strOrder
--如果查询条件不为空,
if @strWhere != ''
set @strSQL='select top '+str(@PageSize)+''+@strGetFields+' from '+@tblName+' where '+@strWhere+''+@strOrder
end
--如果不是第一页,则
else
begin
--以下代码赋予了@strSQL以真正执行的SQL代码 --sql查询语句
set @strSQL = 'select top ' + str(@PageSize) +''+@strGetFields+ ' from '
+ @tblName + ' where ' + @fldName + '' + @strTmp + '('
+ @fldName + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ''
+ @fldName + ' from ' + @tblName + '' + @strOrder + ') as tblTmp)'+ @strOrder --如果查询条件不为空,则另写sql语句
if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize) +''+@strGetFields+ ' from '
+ @tblName + ' where ' + @fldName + '' + @strTmp + '('
+ @fldName + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ''
+ @fldName + ' from ' + @tblName + ' where ' + @strWhere + ''
+ @strOrder + ') as tblTmp) and ' + @strWhere + '' + @strOrder
end
end
exec (@strSQL)
GO --运行存储过程pages
--表名varchar,要返回的列名(*为返回所有)varchar,排序的列varchar,每页显示数量int,
--第几页int,是否统计总数bit,是否降序排列bit,排列条件(不要带where)varchar --统计borrow表的记录数量
exec pages 'uu','*','',0,0,1,0,''
--按borrowid排倒序分别显示1、2、3页的信息
exec pages 'uu','*','uid',4,1,0,1,''
exec pages 'uu','*','uid',4,2,0,1,'uid is not null'
exec pages 'uu','*','uid',4,3,0,1,''
简单改造,调整了参数的顺序,重新进行了命名,以符合的我的使用习惯
if exists(select name from sysobjects where name='pages' and xtype='p')
drop proc pages
go CREATE PROC pages
@bit_DoCount BIT , -- 返回记录总数, 0不返回,1返回
@str_tblName varchar(255), -- 表名
@str_SelectFields varchar(1000), -- 需要返回的列(所有字段*)
@str_Where varchar(1500), -- 查询条件 (注意: 不要加 where)
@str_PkField varchar(255), --主键名称(决定着取出来的记录)
@bit_OrderType bit, -- 设置排序类型, 0升序,1降序
@int_PageSize int, -- 多少条/页
@int_PageIndex int -- 页码
AS declare @strSQL varchar(5000) --主语句
declare @strTmp varchar(150) --临时变量
declare @strOrder varchar(400) --排序类型 --如果@doCount传递过来的不是0,就执行总数统计。
if @bit_DoCount != 0
begin
--查询条件为空
set @strSQL = 'select count(*) as Total from ' + @str_tblName
--查询条件不为空
if @str_Where !=''
set @strSQL = 'select count(*) as Total from ' + @str_tblName + ' where '+@str_Where
end --以下的所有代码都是@doCount为0的情况:
--如果@OrderType是1,就执行降序,否则为升序!
else
begin
--查询条件为空
set @strTmp = '>(select max'
set @strOrder = ' order by ' + @str_PkField +' asc'
--查询条件不为空
if @bit_OrderType = 1
begin
set @strTmp = '<(select min'
set @strOrder = ' order by ' + @str_PkField +' desc'
end --如果是第一页就执行代码,这样会加快执行速度
if @int_PageIndex = 1
begin
--查询条件为空
set @strSQL='select top '+str(@int_PageSize)+' '+@str_SelectFields+' from '+@str_tblName+' '+@strOrder
--如果查询条件不为空,
if @str_Where != ''
set @strSQL='select top '+str(@int_PageSize)+' '+@str_SelectFields+' from '+@str_tblName+' where '+@str_Where+' '+@strOrder
end
--如果不是第一页,则
else
begin
--以下代码赋予了@strSQL以真正执行的SQL代码 --sql查询语句
set @strSQL = 'select top ' + str(@int_PageSize) +' '+@str_SelectFields+ ' from '
+ @str_tblName + ' where ' + @str_PkField + '' + @strTmp + '('
+ @str_PkField + ') from (select top ' + str((@int_PageIndex-1)*@int_PageSize) + ' '
+ @str_PkField + ' from ' + @str_tblName + '' + @strOrder + ') as tblTmp)'+ @strOrder --如果查询条件不为空,则另写sql语句
if @str_Where != ''
set @strSQL = 'select top ' + str(@int_PageSize) +' '+@str_SelectFields+ ' from '
+ @str_tblName + ' where ' + @str_PkField + '' + @strTmp + '('
+ @str_PkField + ') from (select top ' + str((@int_PageIndex-1)*@int_PageSize) + ' '
+ @str_PkField + ' from ' + @str_tblName + ' where ' + @str_Where + ' '
+ @strOrder + ') as tblTmp) and ' + @str_Where + ' ' + @strOrder
end
end
PRINT @strSQL
exec (@strSQL)
GO
mssql分页存储过程的更多相关文章
- SQL Server 2008 通用分页存储过程
1.alert USE [数据库名称] GO /****** Object: StoredProcedure [dbo].[dbTab_PagerHelper] Script Date: 08/22/ ...
- mssql sqlserver存储过程专题
MSSQL存储过程简介及创建方式 mssql_DB_存储过程类型简介 MSSQL sql存储过程创建简介及应用举例 MSSQL SQl server 2008 CLR 存储过程创建举例 MSSQL ...
- 完整的分页存储过程以及c#调用方法
高效分页存储过程 USE [db] GO /****** 对象: StoredProcedure [dbo].[p_Page2005] 脚本日期: // :: ******/ SET ANSI_NUL ...
- 1、SQL可搜索可排序可分页存储过程, 2、范围内的随机时间 适用于sql 2008以上
-- ============================================= -- Author: 蜘蛛王 -- Create date: 2015-10-29 -- Descri ...
- sql server 分页存储过程
----------------------分页存储过程------------------------------------------------------------------------ ...
- MYSQL分页存储过程及事务处理
最近给客户做的一小系统是SQLSERVER的数据库,因为特殊原因要切换到MYSQL上去,切换数据库确实让人头疼的,SQLSERVER和MYSQL的存储过程还是有很大差别的,下面是我做切换时转换的MYS ...
- SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程(支持单表或多表结查集分页)
SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程,支持单表或多表结查集分页,存储过程如下: /******************/ --Author:梦在旅 ...
- C#调用SQL Server分页存储过程
以SQL Server2012提供的offset ..rows fetch next ..rows only为例 e.g. 表名:Tab1 ------------------------------ ...
- 简单的分页存储过程,Json格式日期转换为一般日期
简单的分页存储过程 CREATE PROC Paged @pageIndex INT, @pageCount INT OUTPUT, @pageSize INT AS DECLARE @count I ...
随机推荐
- LINUX 下Open cv练习使用小记(2)
第二节记录一下自己学习图像遍历的一点点代码,摘自<opencv2编程手册>(张静译) 第一个代码是最简单的强行修改像素(添加椒盐噪声) #include <opencv2/core/ ...
- 快速开发一个PHP电影爬虫
今天来做一个PHP电影小爬虫.我们来利用simple_html_dom的采集数据实例,这是一个PHP的库,上手很容易.simple_html_dom 可以很好的帮助我们利用php解析html文档.通过 ...
- js声明json数据,打印json数据,遍历json数据
1.js声明json数据: 2.打印json数据: 3.遍历json数据 //声明JSON var json = {}; json.a = 1; //第一种赋值方式(仿对象型) json['b'] = ...
- 3、NASA NIST Big Data Architecture
这篇关于大数据应用的讲解太好了,直接上图.Mattmann_S1P8_ESTF2015 来自为知笔记(Wiz)
- Linux内核模块设计
内核的设计有两种方式:单内核和微内核,两者各有优劣,关于两者的比较可以参见wiki.windowds和Solaris采用微内核结构. Linux内核采用单内核结构,设计比较简单,但单内核的理念是把所有 ...
- 在Mac上配置adb命令
在Mac上配置adb命令 在Mac OS中使用adb命令时,应进行变量配置,步骤如下: 一.终端中输入 cd ~ 二.输入touch .bash_profile 回车 touch:如果没有,则创建文件 ...
- 关于ckeditor ajax提交到后台 问题
ckeditor 提交时 如果有带有html时是提交不了的 解决办法就是 你在提交的时候 将ckeditor获取的只编码(encodeURI) 然后在传到后台提交的时候 在解码 就ok了 ckname ...
- 《从零开始做一个MEAN全栈项目》(4)
欢迎关注本人的微信公众号"前端小填填",专注前端技术的基础和项目开发的学习. 在上一篇中,我们讲了如何去构建第一个Express项目,总结起来就是使用两个核心工具,express和 ...
- SetTimer 与 回调函数
在控制台应用程序中,SetTimer的函数原型为: UINT_PTR SetTimer( HWND hWnd, // handle to window UINT_PTR nIDEvent, // ti ...
- Eclipse使用tomcat的原理
1. 当我们使用Eclipse将项目部署到Tomcat的时,我们发现,在Tomcat下的webapps目录下并没有我们创建好的项目,但是当通过Eclipse启动服务器后,项目却真的可以访问到,这是为什 ...