十天學會php之第八天

學習目的:做一個分頁顯示

關鍵就是用到瞭SQL語句中的limit來限定顯示的記錄從幾到幾。我們需要一個記錄當前頁的變量$page,還需要總共的記錄數$num

對於$page如果沒有我們就讓它=0,如果有<0就讓它也=0,如果超過瞭總的頁數就讓他=總的頁數。

$execc=”select count(*) from tablename “;
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];

這樣可以得到記錄總數
ceil($num/10))如果一頁10記錄的話,這個就是總的頁數

所以可以這麼寫
if(empty($_GET[page]))
{
$page=0;
}
else
{
$page=$_GET[page];
if($page<0)$page=0;
if($page>=ceil($num/10))$page=ceil($num/10)-1;//因為page是從0開始的,所以要-1
}

這樣$exec可以這麼寫 $exec=”select * from tablename limit “.($page*10).”,10″;
//一頁是10記錄的

最後我們需要做的就是幾個連接:
<a href=”xxx.php?page=0″>FirstPage</a>
<a href=”xxx.php?page=<?=($page-1)?>”>PrevPage</a>
<a href=”xxx.php?page=<?=($page+1)?>”>NextPage</a>
<a href=”xxx.php?page=<?=ceil($num/10)-1?>”>LastPage</a>

這是一個大致的思路,大傢可以想想怎麼來優化?今天說到這裡,明天說一下一些註意的問題。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *