貌似Google的分页的脚本

         /// <param name="total">总记录数</param>
        
/// <param name="per">每页记录数</param>
        
/// <param name="page">当前页数</param>
        
/// <param name="query_string">Url参数</param>
        
/// 返回一个带HTML代码的分页样式(字符串)

         private   string  Pagination( int  total, int  per, int  page, string  query_string)
        
{
            
int allpage=0;
            
int next=0;
            
int pre=0;
            
int startcount=0;
            
int endcount=0;
            
string pagestr="";

            
if(page<1){page=1;}
            
//计算总页数
            if (per != 0)
            
{
                allpage 
= (total / per);
                allpage 
= ((total % per) != 0 ? allpage + 1 : allpage);
                allpage 
= (allpage == 0 ? 1 : allpage);
            }

            next
=page+1;
            pre
=page-1;
            startcount
=(page+5)>allpage?allpage-9:page-4;//中间页起始序号
            
//中间页终止序号
            endcount = page<5 ? 10 : page+5;
            
//endcount = page<5 ? 5 : page+5;
            if(startcount<1{startcount=1;} //为了避免输出的时候产生负数,设置如果小于1就从序号1开始
            if(allpage<endcount){endcount=allpage;}//页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内
            pagestr=""+ allpage +"页      ";
  
            pagestr 
+=page>1 ?  "<a href=""+ query_string + "?page=1">首页</a>&nbsp;<a href=""+ query_string +"?page="+ pre +"">上一页</a>""首页 上一页";
            
//中间页处理,这个增加时间复杂度,减小空间复杂度
            for(int i=startcount;i<=endcount;i++)
            

                pagestr
+=page==i?"  <font color="#ff0000">"+i+"</font>":"  <a href=""+ query_string +"?page="+ i +"">"+ i +"</a>";
            }

            pagestr 
+=page!=allpage ? "  <a href=""+ query_string+"?page="+ next +""> 下一页</a>  <a href=""+ query_string +"?page="+ allpage+"">末页 </a>" : " 下一页 末页";

            
return pagestr;
        }
 可以自己试试修改下,样式没加
不是很好看
改进中.......

(续):今天又看了个sql分页的,但是效率不是很高,却很通用........................
create    procedure  SqlPager
 
@sqlstr   nvarchar ( 4000 ),  -- 查询字符串
  @currentpage   int -- 第N页
  @pagesize   int   -- 每页行数
  as
 
set  nocount  on
 
declare   @P1   int -- P1是游标的id
   @rowcount   int
 
exec  sp_cursoropen  @P1  output, @sqlstr , @scrollopt = 1 , @ccopt = 1 , @rowcount = @rowcount  output
 
select   ceiling ( 1.0 * @rowcount / @pagesize as  总页数, @rowcount   as  总行数, @currentpage   as  当前页 
 
set   @currentpage = ( @currentpage - 1 ) * @pagesize + 1
 
exec  sp_cursorfetch  @P1 , 16 , @currentpage , @pagesize  
 
exec  sp_cursorclose  @P1
 
set  nocount  off
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值