sqlserver通用存储过程

USE [TnpeemSDB]
GO
/****** Object:  StoredProcedure [dbo].[pro_GeneralPaged]    Script Date: 10/26/2015 15:58:50 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- Maticsoft.BLL.list.Lists pro = new Maticsoft.BLL.list.Lists();
 -- 调用方法 DataSet ds = pro.ByPro(PageSize, PageIndex, “查询条件”, ”需要分页的表名”, ”需要分页排序的列名”);
 -- 存储过程方法名固定

 
ALTER procedure [dbo].[pro_GeneralPaged]
   @PageIndex Int,--页码
   @PageSize Int,--每页显示记录
   @StrWhere nvarchar(1000),--Where条件
   @TableName nvarchar(1000), --进行分页的表
   @RowName nvarchar(1000),   --进行分页排序的字段
   @RecordCount Int out,--总记录数
   @PageCount Int out --总页数
   as
   
   declare @SQLSTR nvarchar(4000) --查询语句
   
   IF @RecordCount is null
	BEGIN
		DECLARE @sql nvarchar(4000)
		SET @sql=N'select @RecordCount=count(*)'
			+N' from '+ @TableName +' where 1=1 '
			+N' '+@StrWhere
		EXEC sp_executesql @sql,N'@RecordCount int OUTPUT',@RecordCount output
	END
	set @PageCount =ceiling(@RecordCount*1.0/@PageSize)
	if @PageIndex>@PageCount
	begin
		set @PageIndex=@PageCount
	end
   if @PageIndex<1
	begin
		set @PageIndex=1
	end
	
if @PageIndex=1 or @PageCount<=1
	begin
		set @SQLSTR='select top '+str(@PageSize)+' * from '+ @TableName +' where 1=1 '+ @StrWhere +' order by '+@RowName+' desc'
	end 
	else if @PageIndex=@PageCount
	begin
		set @SQLSTR='select * from (select top '+ str(@RecordCount-@PageSize*(@PageIndex-1))+' * from '+ @TableName +' where 1=1 '+ @StrWhere + ' order by '+@RowName+' asc)  TempTable order by '+@RowName+' desc'
	end
	else 
	begin
		set @SQLSTR='select top '+str(@PageSize)+' * from (select top '+str(@RecordCount-@PageSize*(@PageIndex-1))+' * from '+ @TableName +' where 1=1 '+@StrWhere+'order by '+@RowName+' asc) TempTable order by '+@RowName+' desc'
	end
	set @SQLSTR=@SQLSTR +' select rcount = '+str (@RecordCount)+',pcount='+ str(@PageCount)
	exec (@SQLSTR)

 

posted @ 2015-10-26 16:00  斌言  阅读(200)  评论(0编辑  收藏  举报