这是小弟用的分页存储过程,当参数doCount为0时返回结果集, 非0则返回记录总数,但是在分页时,即需要获得结果集也需要获得返回的记录总数,那就需要调用两次存储过程,觉得太麻烦,想改成当doCount为0时返回结果集, 为1时返回记录总数,为2时即返回结果集又返回记录总数,请问该如何修改?--分页存储过程CREATE PROCEDURE Pagination  
 
@tblName   varchar(255),       -- 表名  
 
@strGetFields varchar(1000) = '*',  -- 需要返回的列  
 
@fldName varchar(255)='',      -- 排序的字段名  
 
@PageSize   int = 10,          -- 页尺寸  
 
@PageIndex  int = 1,           -- 页码  
 
@doCount  bit = 0,   -- 返回记录总数, 非 0 值则返回  
 
@OrderType bit = 0,  -- 设置排序类型, 非 0 值则降序  
 
@strWhere  varchar(1500) = ''  -- 查询条件 (注意: 不要加 where)  
 
AS  
 
declare @strSQL   varchar(5000)       -- 主语句  
 
declare @strTmp   varchar(110)        -- 临时变量  
 
declare @strOrder varchar(400)        -- 排序类型  
 
 
 
if @doCount != 0  
 
 begin  
 
   if @strWhere !=''  
 
   set @strSQL = 'select count(*) as Total from ['+ @tblName +'] where '+ @strWhere  
 
   else  
 
   set @strSQL = 'select count(*) as Total from ['+ @tblName +']' 
 
end  
 
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都 
--是@doCount为0的情况  
 
else  
 
begin  
 
 
 
if @OrderType != 0  
 
begin  
 
   set @strTmp = '<(select min'  
 
set @strOrder = ' order by ['+ @fldName +'] desc' 
 
--如果@OrderType不是0,就执行降序,这句很重要!  
 
end  
 
else  
 
begin  
 
   set @strTmp = '>(select max' 
 
   set @strOrder = ' order by ['+ @fldName +'] asc' 
 
end  
 
 
 
if @PageIndex = 1  
 
begin  
 
   if @strWhere != ''    
 
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] where ' + @strWhere + ' ' + @strOrder  
 
    else  
 
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] '+ @strOrder  
 
--如果是第一页就执行以上代码,这样会加快执行速度  
 
end  
 
else  
 
begin  
 
--以下代码赋予了@strSQL以真正执行的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  
 
 
 
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

解决方案 »

  1.   

    output 参数create proc test
    @output int output
    as
    ...
      

  2.   

    修改如下,doCount取0时能正常返回结果集,取1时也能正常返回记录总数,但取2时仍然只返回记录总数(根取1完全一样),而不是所要的即返回结果集又返回记录总数--分页存储过程CREATE PROCEDURE Pagination  
     
    @tblName   varchar(255),       -- 表名  
     
    @strGetFields varchar(1000) = '*',  -- 需要返回的列  
     
    @fldName varchar(255)='',      -- 排序的字段名  
     
    @PageSize   int = 10,          -- 页尺寸  
     
    @PageIndex  int = 1,           -- 页码  
     
    @doCount  bit = 0,   -- 返回记录总数, 非 0 值则返回  
     
    @OrderType bit = 0,  -- 设置排序类型, 非 0 值则降序  
     
    @strWhere  varchar(1500) = '',  -- 查询条件 (注意: 不要加 where)@rowNum int output  
     
    AS  
     
    declare @strSQL   varchar(5000)       -- 主语句  
     
    declare @strTmp   varchar(110)        -- 临时变量  
     
    declare @strOrder varchar(400)        -- 排序类型  
     
     
     
    if @doCount = 1  
     
     begin  
     
       if @strWhere !=''  
     
       set @strSQL = 'select count(*) as Total from ['+ @tblName +'] where '+ @strWhere  
     
       else  
     
       set @strSQL = 'select count(*) as Total from ['+ @tblName +']' 
     
    end  
     
    --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都 
    --是@doCount为0的情况  
     
    else  
     
    begin  
     
     
     
    if @OrderType != 0  
     
    begin  
     
       set @strTmp = '<(select min'  
     
    set @strOrder = ' order by ['+ @fldName +'] desc' 
     
    --如果@OrderType不是0,就执行降序,这句很重要!  
     
    end  
     
    else  
     
    begin  
     
       set @strTmp = '>(select max' 
     
       set @strOrder = ' order by ['+ @fldName +'] asc' 
     
    end  
     
     
     
    if @PageIndex = 1  
     
    begin  
     
       if @strWhere != ''    
     
        set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] where ' + @strWhere + ' ' + @strOrder  
     
        else  
     
        set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] '+ @strOrder  
     
    --如果是第一页就执行以上代码,这样会加快执行速度  
     
    end  
     
    else  
     
    begin  
     
    --以下代码赋予了@strSQL以真正执行的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  
     
     
     
    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)if @doCount = 2  begin
      
        if @strWhere !=''  
     
          set @strSQL = 'select @rowNum=count(*) from ['+ @tblName +'] where '+ @strWhere  
     
        else  
     
          set @strSQL = 'select @rowNum=count(*) from ['+ @tblName +']'
      
    EXEC sp_executesql @strSQL, N'@rowNum datetime output', @rowNum output       endGO
      

  3.   

    CREATE PROCEDURE Pagination
    @tblName varchar(255), -- 表名
    @strGetFields varchar(1000) = '*', -- 需要返回的列
    @fldName varchar(255)='', -- 排序的字段名
    @PageSize int = 10, -- 页尺寸
    @PageIndex int = 1, -- 页码
    @doCount bit = 0, -- 返回记录总数, 非 0 值则返回
    @OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
    @strWhere varchar(1500) = '', -- 查询条件 (注意: 不要加 where)@Total int output -- 记录总数AS
    declare @strSQL nvarchar(4000) -- 主语句
    declare @strTmp varchar(110) -- 临时变量
    declare @strOrder varchar(400) -- 排序类型
    declare @Total intif @strWhere !=''
    set @strSQL = N'select @Total = count(*) from ['+ @tblName +'] where '+ @strWhere, 
    else
    set @strSQL = N'select @Total = count(*) from ['+ @tblName +']'exec sp_executesql @strSQL, N'@Total int output', @Total output....
      

  4.   

    不行啊,会报错:
    变量名 '@Total' 已声明。变量名在查询批次或存储过程内部必须唯一。
    @Total int output 和 declare @Total int 不能同时声明吧?
      

  5.   

    发布两个大数据集通用分页存储过程,欢迎大家和我联系共同探讨改进方法,同时我也会及时将更新内容发布在下面的网址
    http://www.thinksea.com/thinksea/show.aspx?id=92db4c46-2216-4b24-a72b-aa27fcf82e50