做一個項目,用到了DATALIST,由于分頁的需求,手動寫了分頁的函數(shù)。個人覺得GOOGLE的分頁很不錯,上網(wǎng)查了下資料,修改了下。
這里沒有涉及到數(shù)據(jù)的分頁讀取,只是返回一個帶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 //計算總頁數(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;//中間頁起始序號
27 //中間頁終止序號
28 endcount = page<5 ? 10 : page+5;
29 if(startcount<1) {startcount=1;} //為了避免輸出的時候產(chǎn)生負數(shù),設(shè)置如果小于1就從序號1開始
30 if(allpage<endcount){endcount=allpage;}//頁碼+5的可能性就會產(chǎn)生最終輸出序號大于總頁碼,那么就要將其控制在頁碼數(shù)之內(nèi)
31 pagestr="共"+ allpage +"頁 ";
32
33 pagestr+=page>1 ? "<a href=\""+ query_string + "?page=1\">首頁</a> <a href=\""+ query_string +"?page="+ pre +"\">上一頁</a>": "首頁 上一頁";
34 //中間頁處理,這個增加時間復(fù)雜度,減小空間復(fù)雜度
35 for(int i=startcount;i<=endcount;i++)
36 {
37 pagestr+=page==i?" <font color=\"#ff0000\">"+i+"</font>":" <a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
38 }
39 pagestr+=page!=allpage ? " <a href=\""+ query_string+"?page="+ next +"\">下一頁</a> <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 --返回紀錄總數(shù)用于計算頁面數(shù)
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