關(guān)鍵就是用到了SQL語(yǔ)句中的limit來(lái)限定顯示的記錄從幾到幾。我們需要一個(gè)記錄當(dāng)前頁(yè)的變量$page,還需要總共的記錄數(shù)$num
對(duì)于$page如果沒(méi)有我們就讓它=0,如果有<0就讓它也=0,如果超過(guò)了總的頁(yè)數(shù)就讓他=總的頁(yè)數(shù)。
$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
這樣可以得到記錄總數(shù)
ceil($num/10))如果一頁(yè)10記錄的話,這個(gè)就是總的頁(yè)數(shù)
所以可以這么寫(xiě):
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;//因?yàn)閜age是從0開(kāi)始的,所以要-1
}
這樣$exec可以這么寫(xiě):
$exec="select * from tablename limit ".($page*10).",10";//一頁(yè)是10記錄的
最后我們需要做的就是幾個(gè)連接:
<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>
這是一個(gè)大致的思路,大家可以想想怎么來(lái)優(yōu)化更加速度快一些!