日期:2014-05-19  浏览次数:20569 次

分页存储过程问题
http://community.csdn.net/Expert/topic/5537/5537878.xml?temp=.4858362
http://community.csdn.net/Expert/topic/5540/5540718.xml?temp=.3774225
CREATE   PROCEDURE   spSelectListDynamicPaged2    
(    
  @SelectStatement   nvarchar(4000),    
  @FromStatement   nvarchar(2000),    
  @WhereStatement   nvarchar(4000),    
  @OrderByExpression   nvarchar(500),    
  --add   @AscOrDesc    
  @AscOrDesc   nvarchar(10),    
  @RecordCount   int,    
  @PageSize   int,      
  @PageIndex   int,      
  @DoCount   bit    
)    
   
AS    
   
SET   NOCOUNT   ON    
   
IF(@DoCount=1)    
--if   do   count,   return   the   count   simply    
   
  EXEC( 'SELECT   count(*)     FROM   '+@FromStatement+ '   WHERE   1=1   '+@WhereStatement)    
ELSE    
BEGIN    
   
declare   @nCount   as   int
declare   @nTotalPage   As   int
declare   @sSelectCopy   As   nvarchar(2000)
declare   @TempTable   As   nvarchar(100)

if   isnull(@WhereStatement, ' ')   =   ' '  
begin
set   @WhereStatement   =   '1=1 '
end
else
begin
set   @WhereStatement   =   right(ltrim(@WhereStatement),len(ltrim(@WhereStatement))-3)
end


if   isnull(@OrderByExpression, ' ')   =   ' '
begin
set   @OrderByExpression   =   '1 '
end

if   exists   (select   1   from   sysobjects   where   id   =   object_id( 'tempTablePage1 ')   and   type   =   'U ')
begin
drop   table   tempTablePage1
end

set   @SelectStatement   =     'select   top   100000000   '   +   @SelectStatement


exec   ( 'select   a.*   ,   identity(int,1,1)   as   NumberIndex   into   tempTablePage1   from   ( '   +   @SelectStatement   +   '   from   '   +   @FromStatement   +   '   where   '   +   @WhereStatement   +   '   order   by   '   +   @OrderByExpression   +   '   '   +   @AscOrDesc   + ')   as   a ')

set   @nCount   =   (select   max(NumberIndex)   from   tempTablePage1)
if   @nCount   %   @PageSize   >   0
begin
set   @nTotalPage   =   @nCount   /   @PageSize   +   1
end
else
begin
set   @nTotalPage   =   @nCount   /   @PageSize
end

if   @PageIndex   <=   0  
begin
set   @PageIndex   =   1
end
else   if   @PageIndex   >   @nTotalPage
begin
set   @PageIndex   =   @nTotalPage
end