您好,登錄后才能下訂單哦!
小編給大家分享一下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_class.php");//調用分頁類
$url="url.php?page=" //假設當前頁為 URL.PHP
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_class.php");//調用分頁類
$url="url.php?total=$total&page=" //假設當前頁為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址
}
以上是“PHP怎么樣實現分頁”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。