C#實(shí)現(xiàn)google樣式分頁的函數(shù)

2010-08-28 10:49:09來源:西部e網(wǎng)作者:

做一個(gè)項(xiàng)目,用到了DATALIST,由于分頁的需求,手動(dòng)寫了分頁的函數(shù)。個(gè)人覺得GOOGLE的分頁很不錯(cuò),上網(wǎng)查了下資料,修改了下。
            這里沒有涉及到數(shù)據(jù)的分頁讀取,只是返回一個(gè)帶HTML代碼的分頁樣式(字符串),可以用label在頁面顯示,也可以用this.Controls.Add(new LiteralControl(string));方法加入到頁面控件中。
 1         /**//// <summary>
2         /// 類似GOOGLE的分頁函數(shù),王傳煒,資料參考http://www.phpx.com/happy/viewthread.php?tid=99280&extra=&page=2,謝謝YourEyes
3         /// </summary>
4         /// <param name="total">總記錄數(shù)</param>
5         /// <param name="per">每頁記錄數(shù)</param>
6         /// <param name="page">當(dāng)前頁數(shù)</param>
7         /// <param name="query_string">Url參數(shù)</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             //計(jì)算總頁數(shù)
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;//中間頁起始序號(hào)
27             //中間頁終止序號(hào)
28             endcount = page<5 ? 10 : page+5;
29             if(startcount<1) {startcount=1;} //為了避免輸出的時(shí)候產(chǎn)生負(fù)數(shù),設(shè)置如果小于1就從序號(hào)1開始
30             if(allpage<endcount){endcount=allpage;}//頁碼+5的可能性就會(huì)產(chǎn)生最終輸出序號(hào)大于總頁碼,那么就要將其控制在頁碼數(shù)之內(nèi)
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              //中間頁處理,這個(gè)增加時(shí)間復(fù)雜度,減小空間復(fù)雜度
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         }

如果再加上 分頁存儲(chǔ)過程  就可以滿足大部分需求了。

一個(gè)分頁存儲(chǔ)過程

在這里整理了兩個(gè)可以用的分頁存儲(chǔ)過程,以備后用。

第一:
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              --返回紀(jì)錄總數(shù)用于計(jì)算頁面數(shù)    
\
as
\
begin
\
declare @strSql varchar(500)  --主語句
\
declare @strTemp varchar(100--臨時(shí)變量
\
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        --第一頁直接讀出紀(jì)錄
\
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

關(guān)鍵詞:C#

贊助商鏈接: