asp.net海量分页数据存储过程

存储过程1

  1. CREATE PROCEDURE pagination  
  2. @tblName varchar(255), -- 表名 
  3. @strGetFields varchar(1000) = '*', -- 需要返回的列 
  4. @fldName varchar(255)='', -- 排序的字段名 
  5. @PageSize int , -- 页尺寸 
  6. @PageIndex int, -- 页码 
  7. @doCount bit , -- 返回记录总数, 非 0 值则返回 
  8. @OrderType bit , -- 设置排序类型, 非 0 值则降序 
  9. @strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where) 
  10. AS  
  11. declare @strSQL varchar(5000) -- 主语句 
  12. declare @strTmp varchar(110) -- 临时变量 
  13. declare @strOrder varchar(400) -- 排序类型 
  14. if @doCount != 0  
  15. begin  
  16. if @strWhere !=''  
  17. set @strSQL = "select count(*) as Total from [" + @tblName + "] where "+@strWhere  
  18. else  
  19. set @strSQL = "select count(*) as Total from [" + @tblName + "]"  
  20. end  
  21. --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况 
  22. else  
  23. begin  
  24. if @OrderType != 0  
  25. begin  
  26. set @strTmp = "<(select min"  
  27. set @strOrder = " order by [" + @fldName +"] desc"  
  28. --如果@OrderType不是0,就执行降序,这句很重要! 
  29. end  
  30. else  
  31. begin  
  32. set @strTmp = ">(select max"  
  33. set @strOrder = " order by [" + @fldName +"] asc"  
  34. end  
  35. if @PageIndex = 1  
  36. begin  
  37. if @strWhere != ''  
  38. set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder  
  39. else  
  40. set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] "+ @strOrder  
  41. --如果是第一页就执行以上代码,这样会加快执行速度 
  42. end  
  43. else  
  44. begin  
  45. --以下代码赋予了@strSQL以真正执行的SQL代码 
  46. set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["  
  47. + @tblName + "] where [" + @fldName + "]" + @strTmp + "(["+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"+ @strOrder  
  48. if @strWhere != ''  
  49. set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["  
  50. + @tblName + "] where [" + @fldName + "]" + @strTmp + "(["  
  51. + @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["  
  52. + @fldName + "] from [" + @tblName + "] where " + @strWhere + " "  
  53. + @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder  
  54. end  
  55. end  
  56. exec (@strSQL) 
  57. GO 
  58. 调用的程序
  59.   private static DataSet GetCustomersData(string tblName, string strGetFields,string fldName, int PageSize, int PageIndex, int doCount, int OrderType, string strWhere) 
  60.     string connString = ConfigurationSettings.AppSettings["connstr"]; 
  61.     SqlConnection conn = new SqlConnection(connString); 
  62.     SqlCommand comm = new SqlCommand("pagination3", conn); 
  63.     comm.Parameters.Add(new SqlParameter("@tblName", SqlDbType.VarChar));//表名 
  64.     comm.Parameters[0].Value =tblName ; 
  65.     comm.Parameters.Add(new SqlParameter("@strGetFields", SqlDbType.VarChar));//返回的列 
  66.     comm.Parameters[1].Value = strGetFields; 
  67.     comm.Parameters.Add(new SqlParameter("@fldName", SqlDbType.VarChar));//排序的字段名 
  68.     comm.Parameters[2].Value = fldName; 
  69.     comm.Parameters.Add(new SqlParameter("@PageSize",SqlDbType.Int));//页尺寸 
  70.     comm.Parameters[3].Value = PageSize; 
  71.     comm.Parameters.Add(new SqlParameter("@PageIndex", SqlDbType.Int));//页码 
  72.     comm.Parameters[4].Value = PageIndex; 
  73.     comm.Parameters.Add(new SqlParameter("@doCount", SqlDbType.Int));//是否返回记录总数,0为不返回,1为返回 
  74.     comm.Parameters[5].Value = doCount; 
  75.     comm.Parameters.Add(new SqlParameter("@OrderType", SqlDbType.Int));//设置排序类型,0为升序,非0为降序 
  76.     comm.Parameters[6].Value = OrderType; 
  77.     comm.Parameters.Add(new SqlParameter("@strWhere", SqlDbType.VarChar));//where语句 
  78.     comm.Parameters[7].Value = strWhere; 
  79.     comm.CommandType = CommandType.StoredProcedure; 
  80.     SqlDataAdapter dataAdapter = new SqlDataAdapter(comm); 
  81.     DataSet ds = new DataSet(); 
  82.     dataAdapter.Fill(ds); 
  83.     return ds; 
  84. }

存储过程2

  1. CREATE PROCEDURE [dbo].[GetRecordFromPage]  
  2.     @SelectList            VARCHAR(2000),    --欲选择字段列表
  3.     @TableSource        VARCHAR(100),    --表名或视图表 
  4.     @SearchCondition    VARCHAR(2000),    --查询条件
  5.     @OrderExpression    VARCHAR(1000),    --排序表达式
  6.     @PageIndex            INT = 1,        --页号,从0开始
  7.     @PageSize            INT = 10        --页尺寸
  8. AS  
  9. BEGIN
  10.     IF @SelectList IS NULL OR LTRIM(RTRIM(@SelectList)) = ''
  11.     BEGIN
  12.         SET @SelectList = '*'
  13.     END
  14.     PRINT @SelectList 
  15.      
  16.     SET @SearchCondition = ISNULL(@SearchCondition,''
  17.     SET @SearchCondition = LTRIM(RTRIM(@SearchCondition)) 
  18.     IF @SearchCondition <> ''
  19.     BEGIN
  20.         IF UPPER(SUBSTRING(@SearchCondition,1,5)) <> 'WHERE'
  21.         BEGIN
  22.             SET @SearchCondition = 'WHERE ' + @SearchCondition 
  23.         END
  24.     END
  25.     PRINT @SearchCondition 
  26.     SET @OrderExpression = ISNULL(@OrderExpression,''
  27.     SET @OrderExpression = LTRIM(RTRIM(@OrderExpression)) 
  28.     IF @OrderExpression <> ''
  29.     BEGIN
  30.         IF UPPER(SUBSTRING(@OrderExpression,1,5)) <> 'WHERE'
  31.         BEGIN
  32.             SET @OrderExpression = 'ORDER BY ' + @OrderExpression 
  33.         END
  34.     END
  35.     PRINT @OrderExpression 
  36.     IF @PageIndex IS NULL OR @PageIndex < 1 
  37.     BEGIN
  38.         SET @PageIndex = 1 
  39.     END
  40.     PRINT @PageIndex 
  41.     IF @PageSize IS NULL OR @PageSize < 1 
  42.     BEGIN
  43.         SET @PageSize = 10 
  44.     END
  45.     PRINT  @PageSize 
  46.     DECLARE @SqlQuery VARCHAR(4000) 
  47.     SET @SqlQuery='SELECT '+@SelectList+',RowNumber  
  48.     FROM  
  49.         (SELECT ' + @SelectList + ',ROW_NUMBER() OVER( '+ @OrderExpression +') AS RowNumber  
  50.           FROM '+@TableSource+' '+ @SearchCondition +') AS RowNumberTableSource  
  51.     WHERE RowNumber BETWEEN ' + CAST(((@PageIndex - 1)* @PageSize+1) AS VARCHAR)  
  52.     + ' AND ' +  
  53.     CAST((@PageIndex * @PageSize) AS VARCHAR)  
  54. --    ORDER BY ' + @OrderExpression
  55.     PRINT @SqlQuery 
  56.     SET NOCOUNT ON
  57.     EXECUTE(@SqlQuery) 
  58.     SET NOCOUNT OFF
  59.   
  60.     RETURN @@RowCount 
  61. END

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值