zoukankan      html  css  js  c++  java
  • C#实现google样式分页的函数

    做一个项目,用到了DATALIST,由于分页的需求,手动写了分页的函数。个人觉得GOOGLE的分页很不错,上网查了下资料,修改了下。
                这里没有涉及到数据的分页读取,只是返回一个带HTML代码的分页样式(字符串),可以用label在页面显示,也可以用this.Controls.Add(new LiteralControl(string));方法加入到页面控件中。
     1         /**//// <summary>
    2         /// 类似GOOGLE的分页函数,王传炜,资料参考http://www.phpx.com/happy/viewthread.php?tid=99280&extra=&page=2,谢谢YourEyes
    3         /// </summary>
    4         /// <param name="total">总记录数</param>
    5         /// <param name="per">每页记录数</param>
    6         /// <param name="page">当前页数</param>
    7         /// <param name="query_string">Url参数</param>
    8         private string pagination(int total,int per,int page,string query_string)
    9         {
    10             int allpage=0;
    11             int next=0;
    12             int pre=0;
    13             int startcount=0;
    14             int endcount=0;
    15             string pagestr="";
    16             if(page<1){page=1;}
    17             //计算总页数
    18             if (per != 0)
    19             {
    20                 allpage = (total / per);
    21                 allpage = ((total % per) != 0 ? allpage + 1 : allpage);
    22                 allpage = (allpage == 0 ? 1 : allpage);
    23             }
    24             next=page+1;
    25             pre=page-1;
    26             startcount=(page+5)>allpage?allpage-9:page-4;//中间页起始序号
    27             //中间页终止序号
    28             endcount = page<5 ? 10 : page+5;
    29             if(startcount<1) {startcount=1;} //为了避免输出的时候产生负数,设置如果小于1就从序号1开始
    30             if(allpage<endcount){endcount=allpage;}//页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内
    31             pagestr=""+ allpage +"页&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;";
    32            
    33             pagestr+=page>1 ?  "<a href=\""+ query_string + "?page=1\">首页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ pre +"\">上一页</a>": "首页 上一页";
    34              //中间页处理,这个增加时间复杂度,减小空间复杂度
    35              for(int i=startcount;i<=endcount;i++)
    36              {
    37                  pagestr+=page==i?"&nbsp;&nbsp;<font color=\"#ff0000\">"+i+"</font>":"&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
    38              }
    39              pagestr+=page!=allpage ? "&nbsp;&nbsp;<a href=\""+ query_string+"?page="+ next +"\">下一页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页";
    40
    41             return pagestr;          
    42         }

    如果再加上 分页存储过程  就可以满足大部分需求了。

    一个分页存储过程

    在这里整理了两个可以用的分页存储过程,以备后用。

    第一:
    ALTER  procedure Consignment
    @tablename varchar(80) ,
    @strOrder varchar(50) ,
    @PageIndex int = 1,
    @PageSize int = 15,
    @strGetFields varchar(200) = '*',
    @OutPut int output
    as
    Begin
    Declare @strSql varchar(500)

    DECLARE   @SQL   NVARCHAR(1000)
    DECLARE   @R BIGINT
    SET   @SQL=  N'select @R=count(*) from  '+@TableName
    EXEC  SP_EXECUTESQL   @SQL,  N' @R BIGINT OUTPUT'@R OUTPUT
    SET   @OutPut=  @R

    if(@PageIndex =1)
    Begin
      
    set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' order by '+@strOrder
    End
    Else
      
    set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' where ('+@strOrder
                
    +' >= ( select Max('+@strOrder+') from ( select top '+str(@PageSize*@PageIndex)+' * from '+@tablename+' order by '
                
    +@strOrder+' ) as tempTable)) order by '+ @strOrder
      
    select @strSql 
    exec(@strSql)

    End

    第二:

    alter procedure AllProce
    @tablename varchar(200) ,   --表名
    @strGetFields varchar(200= '*',  --查询列名
    @PageIndex int = 1 ,         --页码
    @pageSize int = 15,         --页面大小
    @strWhere  varchar(100= '',     --查询条件
    @strOrder varchar(100= ''--排序列名
    @intOrder bit = 0,        --排序类型  1为升序
    @CountAll bigint output              --返回纪录总数用于计算页面数    
    as
    begin
    declare @strSql varchar(500)  --主语句
    declare @strTemp varchar(100--临时变量
    declare @strOrders varchar(50--排序语句
    declare @table varchar(70)

    declare   @SQL   nvarchar(1000)
    declare   @R bigint
    set   @SQL=  N'select @R=count(*) from  '+convert(nvarchar(200),@TableName)
    exec  SP_EXECUTESQL   @SQL,  N' @R BIGINT OUTPUT',  @R OUTPUT
    set   @CountAll=  @R
    if @intOrder = 0
    begin
        
    --为0是升序
        set @strTemp = '>(select max'
        
    set @strOrders =  ' order by  '+@strOrder+' asc '
    end
    else
    begin
        
    --否则为降序
        set @strTemp = '<(select min'
        
    set @strOrders = ' order by  '+@strOrder+' desc '
    end
    if @PageIndex =1        --第一页直接读出纪录
    begin
        
    if @strWhere = ''
        
    begin
             
    set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' '+@strOrders
         
    end
        
    else  
        
    begin
             
    set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+ ' from '+@tablename+' where '+@strWhere+' '+@strOrders
        
        
    end
    end
    else
    begin
        
    set @strSql = 'select top'+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strOrder+' '+@strTemp+' ('+@strOrder+')'
                      
    +' from (select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+ ' '+@strOrders+ ') as tempTable ) '+@strOrders
             
        
    if @strWhere != ' '
        
    begin
           
    set @strSql = 'select top '+str(@pageSize)+ ' '+@strGetFields+' from '+@tablename+ ' where '+@strOrder+ ' '+@strTemp+' ('+@strOrder+''
                       
    +' from(select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strWhere+' ' +@strOrders+') as tempTable) where '+@strWhere+' '+@strOrders
       
        
    end
    end 
    exec(@strSql)    
    end
    GO

  • 相关阅读:
    当教育成为一种商品
    怎样设置Solaris上网
    对象转为xml输出到页面,中文乱码问题
    Flex 深拷贝与浅拷贝笔记
    使用access数据库需要注意的问题
    根据数据库表结构生成xsd文件
    SendKeys.Send()输入中文
    VB6迁移到VB.NET的一些问题汇总
    技术文章转移完毕
    说说重复发明轮子的事儿
  • 原文地址:https://www.cnblogs.com/kokoliu/p/487905.html
Copyright © 2011-2022 走看看