PHP分頁效率終結(jié)版(推薦)
更新時間:2013年07月01日 08:58:27 作者:
本篇文章是對PHP分頁的實現(xiàn)進行了詳細的分析介紹,需要的朋友參考下
這里僅展示出設(shè)計思路,具體安全問題,是否同步更新等可根據(jù)具體需求添加修改:
以前人們常用的PHP分頁技術(shù),通常都需要先統(tǒng)計出數(shù)據(jù)庫中總信息條數(shù)才能判斷出總頁數(shù)并對其進行分頁,,也就是說,每次分頁要對數(shù)據(jù)庫進行兩次調(diào)用,在面臨大數(shù)據(jù)量,高并發(fā)查詢情況下是很不效率的,曾經(jīng)一直為這個問題煩惱但都沒想到合適的解決方法,今天突然在睡夢中 遇見奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書寫,為了照顧新人)
原始分頁技術(shù):包括許多開源程序也在使用的技術(shù);
一般都是對數(shù)據(jù)庫信息進行統(tǒng)計,然后調(diào)用分頁類,進行分頁,,每次都要經(jīng)過2次數(shù)據(jù)庫查詢操作
例(原始分頁技術(shù)): 每次都要進行2次數(shù)據(jù)庫查詢
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫調(diào)用
$total=$info["total"];//每次翻頁都要進行 總信息條數(shù) 的數(shù)據(jù)庫查詢操作
$pagesize=10; //每頁顯示數(shù)量
$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");//第二次數(shù)據(jù)庫查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁類
$url="url.php?page=" //假設(shè)當前頁為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址
}
//優(yōu)化后的分頁技術(shù)(只需在第一次調(diào)用時進行信息統(tǒng)計即可)
if(isset($_GET["total"])){ //只需要進行一次總信息條數(shù)的統(tǒng)計即可
$total=intval($_GET["total"]);
//以后的的總信息數(shù)量通過GET傳遞即可,節(jié)省了1/2的數(shù)據(jù)庫負荷,,,,
}else{
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫調(diào)用
$total=$info["total"];
}//總信息條數(shù)
$pagesize=10; //每頁顯示數(shù)量
$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");//第二次數(shù)據(jù)庫查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁類
$url="url.php?total=$total&page=" //假設(shè)當前頁為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址
}
以前人們常用的PHP分頁技術(shù),通常都需要先統(tǒng)計出數(shù)據(jù)庫中總信息條數(shù)才能判斷出總頁數(shù)并對其進行分頁,,也就是說,每次分頁要對數(shù)據(jù)庫進行兩次調(diào)用,在面臨大數(shù)據(jù)量,高并發(fā)查詢情況下是很不效率的,曾經(jīng)一直為這個問題煩惱但都沒想到合適的解決方法,今天突然在睡夢中 遇見奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書寫,為了照顧新人)
原始分頁技術(shù):包括許多開源程序也在使用的技術(shù);
一般都是對數(shù)據(jù)庫信息進行統(tǒng)計,然后調(diào)用分頁類,進行分頁,,每次都要經(jīng)過2次數(shù)據(jù)庫查詢操作
例(原始分頁技術(shù)): 每次都要進行2次數(shù)據(jù)庫查詢
復(fù)制代碼 代碼如下:
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫調(diào)用
$total=$info["total"];//每次翻頁都要進行 總信息條數(shù) 的數(shù)據(jù)庫查詢操作
$pagesize=10; //每頁顯示數(shù)量
$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");//第二次數(shù)據(jù)庫查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁類
$url="url.php?page=" //假設(shè)當前頁為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址
}
//優(yōu)化后的分頁技術(shù)(只需在第一次調(diào)用時進行信息統(tǒng)計即可)
if(isset($_GET["total"])){ //只需要進行一次總信息條數(shù)的統(tǒng)計即可
$total=intval($_GET["total"]);
//以后的的總信息數(shù)量通過GET傳遞即可,節(jié)省了1/2的數(shù)據(jù)庫負荷,,,,
}else{
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫調(diào)用
$total=$info["total"];
}//總信息條數(shù)
$pagesize=10; //每頁顯示數(shù)量
$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");//第二次數(shù)據(jù)庫查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁類
$url="url.php?total=$total&page=" //假設(shè)當前頁為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁的URL地址
}
您可能感興趣的文章:
- php實現(xiàn)分頁工具類分享
- PHP分頁詳細講解(有實例)
- 一個簡單且很好用的php分頁類
- 學(xué)習(xí)php分頁代碼實例
- 實用的簡單PHP分頁集合包括使用方法
- thinkphp 一個頁面使用2次分頁的實現(xiàn)方法
- 用php制作簡單分頁(從數(shù)據(jù)庫讀取記錄)的方法詳解
- 使用PHP+JQuery+Ajax分頁的實現(xiàn)
- 精美漂亮的php分頁類代碼
- 仿Aspnetpager的一個PHP分頁類代碼 附源碼下載
- php中長文章分頁顯示實現(xiàn)代碼
- php 解決舊系統(tǒng) 查出所有數(shù)據(jù)分頁的類
- 無JS,完全php面向過程數(shù)據(jù)分頁實現(xiàn)代碼
- PHP 文本文章分頁代碼 按標記或長度(不涉及數(shù)據(jù)庫)
- php分頁思路以及在Zend?Framework框架中的使用
- php開發(fā)分頁實現(xiàn)代碼
- PHP動態(tài)分頁函數(shù),PHP開發(fā)分頁必備啦
- php分頁代碼學(xué)習(xí)示例分享
相關(guān)文章
PHP正則匹配日期和時間(時間戳轉(zhuǎn)換)的實例代碼
本文介紹下,用php實現(xiàn)正則匹配日期與時間,并進行時間戳轉(zhuǎn)換的例子,有需要的朋友,參考下吧2016-12-12
php XPath對XML文件查找及修改實現(xiàn)代碼
php XPath對XML文件查找及修改實現(xiàn)代碼,需要的朋友可以參考下。2011-07-07
解析PHP強制轉(zhuǎn)換類型及遠程管理插件的安全隱患
這篇文章主要介紹了PHP強制轉(zhuǎn)換類型及遠程管理插件的安全隱患,需要的朋友可以參考下2014-06-06

