一般都是用mysql 的limit 功能來(lái)實(shí)現(xiàn)分頁(yè)。
成都創(chuàng)新互聯(lián)公司專(zhuān)業(yè)為企業(yè)提供臨桂網(wǎng)站建設(shè)、臨桂做網(wǎng)站、臨桂網(wǎng)站設(shè)計(jì)、臨桂網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、臨桂企業(yè)網(wǎng)站模板建站服務(wù),10年臨桂做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
select * from table limit $begin,$end
$begin=0;
$end=10;
即顯示開(kāi)始0-10個(gè)數(shù)據(jù)。
?php
class?Page?{
private?$total;?//數(shù)據(jù)表中總記錄數(shù)
private?$listRows;?//每頁(yè)顯示行數(shù)
private?$limit;
private?$uri;
private?$pageNum;?//頁(yè)數(shù)
private?$config=array('header'="個(gè)記錄",?"prev"="上一頁(yè)",?"next"="下一頁(yè)",?"first"="首?頁(yè)",?"last"="尾?頁(yè)");
private?$listNum=8;
/*
*?$total?
*?$listRows
*/
public?function?__construct($total,?$listRows=10,?$pa=""){
$this-total=$total;
$this-listRows=$listRows;
$this-uri=$this-getUri($pa);
$this-page=!empty($_GET["page"])???$_GET["page"]?:?1;
$this-pageNum=ceil($this-total/$this-listRows);
$this-limit=$this-setLimit();
}
private?function?setLimit(){
return?"Limit?".($this-page-1)*$this-listRows.",?{$this-listRows}";
}
private?function?getUri($pa){
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"],?'?')?'':"?").$pa;
$parse=parse_url($url);
if(isset($parse["query"])){
parse_str($parse['query'],$params);
unset($params["page"]);
$url=$parse['path'].'?'.http_build_query($params);
}
return?$url;
}
private?function?__get($args){
if($args=="limit")
return?$this-limit;
else
return?null;
}
private?function?start(){
if($this-total==0)
return?0;
else
return?($this-page-1)*$this-listRows+1;
}
private?function?end(){
return?min($this-page*$this-listRows,$this-total);
}
private?function?first(){
if($this-page==1)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=1\")'{$this-config["first"]}/anbsp;nbsp;";
return?$html;
}
private?function?prev(){
if($this-page==1)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-page-1)."\")'{$this-config["prev"]}/anbsp;nbsp;";
return?$html;
}
private?function?pageList(){
$linkPage="";
$inum=floor($this-listNum/2);
for($i=$inum;?$i=1;?$i--){
$page=$this-page-$i;
if($page1)
continue;
$linkPage.="nbsp;a?href='javascript:setPage(\"{$this-uri}page={$page}\")'{$page}/anbsp;";
}
$linkPage.="nbsp;{$this-page}nbsp;";
for($i=1;?$i=$inum;?$i++){
$page=$this-page+$i;
if($page=$this-pageNum)
$linkPage.="nbsp;a?href='javascript:setPage(\"{$this-uri}page={$page}\")'{$page}/anbsp;";
else
break;
}
return?$linkPage;
}
private?function?next(){
if($this-page==$this-pageNum)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-page+1)."\")'{$this-config["next"]}/anbsp;nbsp;";
return?$html;
}
private?function?last(){
if($this-page==$this-pageNum)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-pageNum)."\")'{$this-config["last"]}/anbsp;nbsp;";
return?$html;
}
private?function?goPage(){
return?'nbsp;nbsp;input?type="text"?onkeydown="javascript:if(event.keyCode==13){var?page=(this.value'.$this-pageNum.')?'.$this-pageNum.':this.value;setPage(\''.$this-uri.'page=\'+page+\'\')}"?value="'.$this-page.'"?style="width:25px"input?type="button"?value="GO"?onclick="javascript:var?page=(this.previousSibling.value'.$this-pageNum.')?'.$this-pageNum.':this.previousSibling.value;setPage(\''.$this-uri.'page=\'+page+\'\')"nbsp;nbsp;';
}
function?fpage($display=array(0,1,2,3,4,5,6,7,8)){
$html[0]="nbsp;nbsp;共有b{$this-total}/b{$this-config["header"]}nbsp;nbsp;";
$html[1]="nbsp;nbsp;每頁(yè)顯示b".($this-end()-$this-start()+1)."/b條,本頁(yè)b{$this-start()}-{$this-end()}/b條nbsp;nbsp;";
$html[2]="nbsp;nbsp;b{$this-page}/{$this-pageNum}/b頁(yè)nbsp;nbsp;";
$html[3]=$this-first();
$html[4]=$this-prev();
$html[5]=$this-pageList();
$html[6]=$this-next();
$html[7]=$this-last();
$html[8]=$this-goPage();
$fpage='';
foreach($display?as?$index){
$fpage.=$html[$index];
}
return?$fpage;
}
}
我覺(jué)得你可以這樣。你可以在相關(guān)表中添加一個(gè)字段,比如limit,當(dāng)然這個(gè)limit可以在配置文件中自由設(shè)置。然后可以這樣 select count(id) as count,limit from tablename。
PHP代碼如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那么頁(yè)數(shù)就是1。
$num=10; //每頁(yè)顯示10條數(shù)據(jù)
$db=mysql_connect("host","name","pass"); //創(chuàng)建數(shù)據(jù)庫(kù)連接
$select=mysql_select_db("db",$db); //選擇要操作的數(shù)據(jù)庫(kù)
/*
首先咱們要獲取數(shù)據(jù)庫(kù)中到底有多少數(shù)據(jù),才能判斷具體要分多少頁(yè),具體的公式就是
總數(shù)據(jù)數(shù)除以每頁(yè)顯示的條數(shù),有余進(jìn)一。
也就是說(shuō)10/3=3.3333=4 有余數(shù)就要進(jìn)一。
*/
$total=mysql_num_rows(mysql_query("select id from table")); //查詢數(shù)據(jù)的總數(shù),id是數(shù)據(jù)庫(kù)中的一個(gè)自動(dòng)賦值的字段
$pagenum=ceil($total/$num); //獲得總頁(yè)數(shù)
//假如傳入的頁(yè)數(shù)參數(shù)大于總頁(yè)數(shù),則顯示錯(cuò)誤信息
If($page$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}
$offset=($page-1)*$num; //獲取limit的第一個(gè)參數(shù)的值,假如第一頁(yè)則為(1-1)*10=0,第二頁(yè)為(2-1)*10=10。
$info=mysql_query("select name from table limit $offset,$num"); //獲取相應(yīng)頁(yè)數(shù)所需要顯示的數(shù)據(jù),name是數(shù)據(jù)里的一個(gè)字段
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數(shù)據(jù)
For($i=1;$i=$pagenum;$i++){
$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}
/*顯示分頁(yè)信息,假如是當(dāng)頁(yè)則顯示粗體的數(shù)字,其余的頁(yè)數(shù)則為超連接,假如當(dāng)前為第三頁(yè)則顯示如下
1 2 3 4 5 6
*/
?
說(shuō)明你點(diǎn)下一頁(yè)的時(shí)候,查詢條件沒(méi)有獲取到,下一頁(yè)的是連接,所以接受數(shù)據(jù)參數(shù)的時(shí)候需要用$_GET 來(lái)接收,提交的時(shí)候也需要用get方法提交,這樣才能保證參數(shù)不會(huì)丟失,點(diǎn)擊下一頁(yè)的時(shí)候限制條件保持一致
你的頁(yè)面跳轉(zhuǎn), 要把原來(lái)有的get參數(shù)一同傳遞下去!
因?yàn)椋?如果你第一頁(yè)就是根據(jù)相關(guān)get參數(shù)查詢的數(shù)據(jù)庫(kù), 而你在下一頁(yè)沒(méi)有提供這個(gè)參數(shù), 當(dāng)然會(huì)查詢不到!
get參數(shù)是在當(dāng)前頁(yè)面有效的, 一般, get參數(shù)是url提供, 你url有就有, 沒(méi)有就沒(méi)有, 不是你提供一次, 人家就會(huì)給你保存一輩子!
例外, 你這個(gè)php文件, 功能其實(shí)很簡(jiǎn)單對(duì)吧?但你有沒(méi)有覺(jué)得, 代碼密密麻麻呢?
如果讓你寫(xiě)一個(gè)大型網(wǎng)站, 那你的代碼豈不是要用東風(fēng)牌大卡車(chē)來(lái)裝呢?
當(dāng)前題目:php數(shù)據(jù)庫(kù)獲得數(shù)據(jù)分頁(yè),數(shù)據(jù)庫(kù)的分頁(yè)
本文網(wǎng)址:http://jinyejixie.com/article0/hojsoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開(kāi)發(fā)、自適應(yīng)網(wǎng)站、建站公司、網(wǎng)站維護(hù)、全網(wǎng)營(yíng)銷(xiāo)推廣、標(biāo)簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容