高效分頁存儲過程

 /****** 对象:  StoredProcedure [dbo].[PageList]    脚本日期: 09/05/2008 23:57:19 ******/
SET ANSI_NULLS OFF
GO
SET QUOTED_IDENTIFIER OFF
GO
ALTER PROCEDURE [dbo].[PageList]

@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)

 


        /// <summary>
        /// 利用通用存储过程实现快速分页
        /// </summary>
        /// <param name="tblName">表名</param>
        /// <param name="strGetFields">字段名,用逗号分隔</param>
        /// <param name="fldName">排序字段</param>
        /// <param name="PageSize">每页显示记录数</param>
        /// <param name="PageIndex">当前页</param>
        /// <param name="doCount">返回记录总数, 非 0 值则返回</param>
        /// <param name="OrderType">设置排序类型, 非 0 值则降序</param>
        /// <param name="strWhere">查询条件 (注意: 不要加 where)</param>
        /// <returns>返回DataTable</returns>
        public DataTable Page_List(string tblName, string strGetFields, string fldName, int PageSize, int PageIndex, int doCount, int OrderType, string strWhere)
        {
            //tblName表名
            //strGetFields 字段名,用逗号分隔
            //fldName排序字段
            //PageSize每页显示记录数
            //PageIndex当前页
            //doCount返回记录总数, 非 0 值则返回
            //OrderType设置排序类型, 非 0 值则降序
            //strWhere查询条件 (注意: 不要加 where)
            //SqlDataAdapter rs = new SqlDataAdapter("PageList", conn);
            //int AllCount = 0;
            //AllCount = GetTableCount(tblName, strWhere);
            SqlCommand myCommand = new SqlCommand("PageList", conn);
            myCommand.CommandType = CommandType.StoredProcedure;//命令类型

            myCommand.Parameters.Add(new SqlParameter("@tblName", SqlDbType.VarChar, 100));
            myCommand.Parameters["@tblName"].Value = tblName;

            myCommand.Parameters.Add(new SqlParameter("@strGetFields", SqlDbType.VarChar, 1000));
            myCommand.Parameters["@strGetFields"].Value = strGetFields;

            myCommand.Parameters.Add(new SqlParameter("@fldName", SqlDbType.VarChar, 50));
            myCommand.Parameters["@fldName"].Value = fldName;

            myCommand.Parameters.Add(new SqlParameter("@PageSize", SqlDbType.Int, 4));
            myCommand.Parameters["@PageSize"].Value = PageSize;

            myCommand.Parameters.Add(new SqlParameter("@PageIndex", SqlDbType.Int, 4));
            myCommand.Parameters["@PageIndex"].Value = PageIndex;

            myCommand.Parameters.Add(new SqlParameter("@doCount", SqlDbType.Int, 4));
            myCommand.Parameters["@doCount"].Value = doCount;

            myCommand.Parameters.Add(new SqlParameter("@OrderType", SqlDbType.Int, 4));
            myCommand.Parameters["@OrderType"].Value = OrderType;

            myCommand.Parameters.Add(new SqlParameter("@strWhere", SqlDbType.VarChar, 1000));
            myCommand.Parameters["@strWhere"].Value = strWhere;

            DataTable dt = new DataTable("showClass");
            SqlDataAdapter rs = new SqlDataAdapter(myCommand);
            rs.Fill(dt);

            myCommand.Dispose();
            rs.Dispose();
            return dt;

        }

 


 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值