網頁設計

當前位置 /首頁/設計製作/網頁設計/列表

PHP分頁效率加強版

這裡僅展示出設計思路,具體安全問題,是否同步更新等可根據具體需求新增修改:

PHP分頁效率加強版

以前人們常用的PHP分頁技術,通常都需要先統計出資料庫中總資訊條數才能判斷出總頁數並對其進行分頁,,也就是說,每次分頁要對資料庫進行兩次呼叫,在面臨大資料量,高併發查詢情況下是很不效率的,曾經一直為這個問題煩惱但都沒想到合適的`解決方法,今天突然在睡夢中 遇見奇蹟...具體分析原理如下:(紅色部分為優化後的區別,思路採用最原始的程式碼書寫,為了照顧新人)

原始分頁技術:包括許多開源程式也在使用的技術;

一般都是對資料庫資訊進行統計,然後呼叫分頁類,進行分頁,,每次都要經過2次資料庫查詢操作

例(原始分頁技術): 每次都要進行2次資料庫查詢

複製程式碼 程式碼如下:

$sqlstr="select count(*) as total from tablename";

$sql=mysql_query($sql) or die("error");

$info=mysql_fetch_array($sql); //第一次 資料庫呼叫

$total=$info["total"];//每次翻頁都要進行 總資訊條數 的資料庫查詢操作

$pagesize=10; //每頁顯示數量

$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當前頁

if($total){,

$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";

$sql=mysql_query($sql) or die("error");//第二次資料庫查詢操作

$info=mysql_fetch_array($sql);

do{

...............

}while($info=mysql_fetch_array($sql));

include("page_");//呼叫分頁類

$url=" //假設當前頁為

echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址

}

//優化後的分頁技術(只需在第一次呼叫時進行資訊統計即可)

if(isset($_GET["total"])){ //只需要進行一次總資訊條數的統計即可

$total=intval($_GET["total"]);

//以後的的總資訊數量通過GET傳遞即可,節省了1/2的資料庫負荷,,,,

}else{

$sqlstr="select count(*) as total from tablename";

$sql=mysql_query($sql) or die("error");

$info=mysql_fetch_array($sql); //第一次 資料庫呼叫

$total=$info["total"];

}//總資訊條數

$pagesize=10; //每頁顯示數量

$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當前頁

if($total){

$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";

$sql=mysql_query($sql) or die("error");//第二次資料庫查詢操作

$info=mysql_fetch_array($sql);

do{

...............

}while($info=mysql_fetch_array($sql));

include("page_");//呼叫分頁類

$url="$total&page=" //假設當前頁為

echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址

}

TAG標籤:PHP 效率 分頁 加強版 #