基于SQL Server 2005新特性的分页存储过程
2011-04-18 22:51
573 查看
/*
名称:PagingRecord
作用:按任意字段进行排序分页
作者:谢忠领
时间:2007-2-1
声明:此代码你可以无偿使用及转载,但在转载时,请勿移称本文字声明
*/
CREATE PROCEDURE [dbo].[PagingRecord]
(
@PageIndex int,--页号,从0开始
@PageSize int,--页尺寸
@OrderField varchar(100),--排序字段及类型(多个条件用逗号分开)如:JobID DESC,Checkintime
@TableName varchar(100),--表名或视图表
@StrWhere varchar(2000),--条件
@FieldList varchar(2000),--欲选择字段列表
@DoCount AS bit=1-- 0值返回记录总数, 非 0 值则返回记录
)
AS
BEGIN TRAN
DECLARE @SqlQuery varchar(4000)
IF @DoCount<>0
Goto GetCount
Else
Goto GetSearch
GetCount:--返回记录总数
DECLARE @SearchSql AS Nvarchar(4000)
SET @SearchSql= 'SELECT Count(*) AS Total FROM '+@TableName+' WHERE '+@StrWhere
exec sp_executesql @SearchSql
--print @SearchSql
COMMIT TRAN
return
GetSearch:
SET @SqlQuery='SELECT '+@FieldList+'
FROM (SELECT row_number() over(ORDER BY '+@OrderField+') as rownum,
'+@FieldList+'
FROM '+@TableName+' WHERE '+@StrWhere +') as temp
WHERE rownum BETWEEN ('+cast(@PageIndex as varchar)+'-1)*'+cast(@PageSize as varchar)+'+1 and '+cast(@PageIndex as varchar)+'*'+cast(@PageSize as varchar) + ' ORDER BY '+@OrderField
--print @SqlQuery
SET NOCOUNT ON
execute(@SqlQuery)
SET NOCOUNT OFF
COMMIT TRAN
名称:PagingRecord
作用:按任意字段进行排序分页
作者:谢忠领
时间:2007-2-1
声明:此代码你可以无偿使用及转载,但在转载时,请勿移称本文字声明
*/
CREATE PROCEDURE [dbo].[PagingRecord]
(
@PageIndex int,--页号,从0开始
@PageSize int,--页尺寸
@OrderField varchar(100),--排序字段及类型(多个条件用逗号分开)如:JobID DESC,Checkintime
@TableName varchar(100),--表名或视图表
@StrWhere varchar(2000),--条件
@FieldList varchar(2000),--欲选择字段列表
@DoCount AS bit=1-- 0值返回记录总数, 非 0 值则返回记录
)
AS
BEGIN TRAN
DECLARE @SqlQuery varchar(4000)
IF @DoCount<>0
Goto GetCount
Else
Goto GetSearch
GetCount:--返回记录总数
DECLARE @SearchSql AS Nvarchar(4000)
SET @SearchSql= 'SELECT Count(*) AS Total FROM '+@TableName+' WHERE '+@StrWhere
exec sp_executesql @SearchSql
--print @SearchSql
COMMIT TRAN
return
GetSearch:
SET @SqlQuery='SELECT '+@FieldList+'
FROM (SELECT row_number() over(ORDER BY '+@OrderField+') as rownum,
'+@FieldList+'
FROM '+@TableName+' WHERE '+@StrWhere +') as temp
WHERE rownum BETWEEN ('+cast(@PageIndex as varchar)+'-1)*'+cast(@PageSize as varchar)+'+1 and '+cast(@PageIndex as varchar)+'*'+cast(@PageSize as varchar) + ' ORDER BY '+@OrderField
--print @SqlQuery
SET NOCOUNT ON
execute(@SqlQuery)
SET NOCOUNT OFF
COMMIT TRAN
相关文章推荐
- 基于SQL Server 2005新特性的分页存储过程
- Sql server 2005的分页存储过程,利用ROW_NUMBER()新特性
- Sql server 2005的分页存储过程,利用ROW_NUMBER()新特性
- sql server 2005分页存储过程和sql server 2000分页存储过程
- Sql Server 存储过程分页大全(2005,2000)
- SQL SERVER 2005分页存储过程
- 基于SQL SERVER 分页的存储过程
- sql server 2005分页存储过程和sql server 2000分页存储过程(转,来源不明)
- 根据表或者视图自动生成分页语句的存储过程,适用于Sql Server 2005及以上版本
- 简单谈基于SQL SERVER 分页存储过程的演进
- 基于SQL SERVER 分页存储过程的演进
- sql server 2005分页存储过程和sql server 2000分页存储过程
- 简单讲述基于SQL SERVER 分页的存储过程
- Hibernate 调用SQL Server 2005 分页存储过程
- SQL Server 2005 分页存储过程 row_number()
- 简单谈基于SQL SERVER 分页存储过程的演进
- 深入sql server 2005 万能分页存储过程的详解
- 简单谈基于SQL SERVER 分页存储过程的演进
- 简单谈基于SQL SERVER 分页存储过程的演进
- sql server 2005分页存储过程和sql server 2000分页存储过程(摘)