PHP分頁(yè)效率終結(jié)版(推薦)
更新時(shí)間:2013年07月01日 08:58:27 作者:
本篇文章是對(duì)PHP分頁(yè)的實(shí)現(xiàn)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
這里僅展示出設(shè)計(jì)思路,具體安全問(wèn)題,是否同步更新等可根據(jù)具體需求添加修改:
以前人們常用的PHP分頁(yè)技術(shù),通常都需要先統(tǒng)計(jì)出數(shù)據(jù)庫(kù)中總信息條數(shù)才能判斷出總頁(yè)數(shù)并對(duì)其進(jìn)行分頁(yè),,也就是說(shuō),每次分頁(yè)要對(duì)數(shù)據(jù)庫(kù)進(jìn)行兩次調(diào)用,在面臨大數(shù)據(jù)量,高并發(fā)查詢情況下是很不效率的,曾經(jīng)一直為這個(gè)問(wèn)題煩惱但都沒(méi)想到合適的解決方法,今天突然在睡夢(mèng)中 遇見(jiàn)奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書寫,為了照顧新人)
原始分頁(yè)技術(shù):包括許多開(kāi)源程序也在使用的技術(shù);
一般都是對(duì)數(shù)據(jù)庫(kù)信息進(jìn)行統(tǒng)計(jì),然后調(diào)用分頁(yè)類,進(jìn)行分頁(yè),,每次都要經(jīng)過(guò)2次數(shù)據(jù)庫(kù)查詢操作
例(原始分頁(yè)技術(shù)): 每次都要進(jìn)行2次數(shù)據(jù)庫(kù)查詢
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫(kù)調(diào)用
$total=$info["total"];//每次翻頁(yè)都要進(jìn)行 總信息條數(shù) 的數(shù)據(jù)庫(kù)查詢操作
$pagesize=10; //每頁(yè)顯示數(shù)量
$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當(dāng)前頁(yè)
if($total){,
$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";
$sql=mysql_query($sql) or die("error");//第二次數(shù)據(jù)庫(kù)查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類
$url="url.php?page=" //假設(shè)當(dāng)前頁(yè)為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁(yè)的URL地址
}
//優(yōu)化后的分頁(yè)技術(shù)(只需在第一次調(diào)用時(shí)進(jìn)行信息統(tǒng)計(jì)即可)
if(isset($_GET["total"])){ //只需要進(jìn)行一次總信息條數(shù)的統(tǒng)計(jì)即可
$total=intval($_GET["total"]);
//以后的的總信息數(shù)量通過(guò)GET傳遞即可,節(jié)省了1/2的數(shù)據(jù)庫(kù)負(fù)荷,,,,
}else{
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫(kù)調(diào)用
$total=$info["total"];
}//總信息條數(shù)
$pagesize=10; //每頁(yè)顯示數(shù)量
$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當(dāng)前頁(yè)
if($total){
$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";
$sql=mysql_query($sql) or die("error");//第二次數(shù)據(jù)庫(kù)查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類
$url="url.php?total=$total&page=" //假設(shè)當(dāng)前頁(yè)為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁(yè)的URL地址
}
以前人們常用的PHP分頁(yè)技術(shù),通常都需要先統(tǒng)計(jì)出數(shù)據(jù)庫(kù)中總信息條數(shù)才能判斷出總頁(yè)數(shù)并對(duì)其進(jìn)行分頁(yè),,也就是說(shuō),每次分頁(yè)要對(duì)數(shù)據(jù)庫(kù)進(jìn)行兩次調(diào)用,在面臨大數(shù)據(jù)量,高并發(fā)查詢情況下是很不效率的,曾經(jīng)一直為這個(gè)問(wèn)題煩惱但都沒(méi)想到合適的解決方法,今天突然在睡夢(mèng)中 遇見(jiàn)奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書寫,為了照顧新人)
原始分頁(yè)技術(shù):包括許多開(kāi)源程序也在使用的技術(shù);
一般都是對(duì)數(shù)據(jù)庫(kù)信息進(jìn)行統(tǒng)計(jì),然后調(diào)用分頁(yè)類,進(jìn)行分頁(yè),,每次都要經(jīng)過(guò)2次數(shù)據(jù)庫(kù)查詢操作
例(原始分頁(yè)技術(shù)): 每次都要進(jìn)行2次數(shù)據(jù)庫(kù)查詢
復(fù)制代碼 代碼如下:
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫(kù)調(diào)用
$total=$info["total"];//每次翻頁(yè)都要進(jìn)行 總信息條數(shù) 的數(shù)據(jù)庫(kù)查詢操作
$pagesize=10; //每頁(yè)顯示數(shù)量
$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當(dāng)前頁(yè)
if($total){,
$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";
$sql=mysql_query($sql) or die("error");//第二次數(shù)據(jù)庫(kù)查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類
$url="url.php?page=" //假設(shè)當(dāng)前頁(yè)為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁(yè)的URL地址
}
//優(yōu)化后的分頁(yè)技術(shù)(只需在第一次調(diào)用時(shí)進(jìn)行信息統(tǒng)計(jì)即可)
if(isset($_GET["total"])){ //只需要進(jìn)行一次總信息條數(shù)的統(tǒng)計(jì)即可
$total=intval($_GET["total"]);
//以后的的總信息數(shù)量通過(guò)GET傳遞即可,節(jié)省了1/2的數(shù)據(jù)庫(kù)負(fù)荷,,,,
}else{
$sqlstr="select count(*) as total from tablename";
$sql=mysql_query($sql) or die("error");
$info=mysql_fetch_array($sql); //第一次 數(shù)據(jù)庫(kù)調(diào)用
$total=$info["total"];
}//總信息條數(shù)
$pagesize=10; //每頁(yè)顯示數(shù)量
$page=$_GET["page"]?max(intval($_GET["page"]),1):1;//當(dāng)前頁(yè)
if($total){
$sql="select * from tablename limit "($page-1)*$pagesize",$pagesize";
$sql=mysql_query($sql) or die("error");//第二次數(shù)據(jù)庫(kù)查詢操作
$info=mysql_fetch_array($sql);
do{
...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類
$url="url.php?total=$total&page=" //假設(shè)當(dāng)前頁(yè)為 URL.PHP
echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 為要分頁(yè)的URL地址
}
您可能感興趣的文章:
- php實(shí)現(xiàn)分頁(yè)工具類分享
- PHP分頁(yè)詳細(xì)講解(有實(shí)例)
- 一個(gè)簡(jiǎn)單且很好用的php分頁(yè)類
- 學(xué)習(xí)php分頁(yè)代碼實(shí)例
- 實(shí)用的簡(jiǎn)單PHP分頁(yè)集合包括使用方法
- thinkphp 一個(gè)頁(yè)面使用2次分頁(yè)的實(shí)現(xiàn)方法
- 用php制作簡(jiǎn)單分頁(yè)(從數(shù)據(jù)庫(kù)讀取記錄)的方法詳解
- 使用PHP+JQuery+Ajax分頁(yè)的實(shí)現(xiàn)
- 精美漂亮的php分頁(yè)類代碼
- 仿Aspnetpager的一個(gè)PHP分頁(yè)類代碼 附源碼下載
- php中長(zhǎng)文章分頁(yè)顯示實(shí)現(xiàn)代碼
- php 解決舊系統(tǒng) 查出所有數(shù)據(jù)分頁(yè)的類
- 無(wú)JS,完全php面向過(guò)程數(shù)據(jù)分頁(yè)實(shí)現(xiàn)代碼
- PHP 文本文章分頁(yè)代碼 按標(biāo)記或長(zhǎng)度(不涉及數(shù)據(jù)庫(kù))
- php分頁(yè)思路以及在Zend?Framework框架中的使用
- php開(kāi)發(fā)分頁(yè)實(shí)現(xiàn)代碼
- PHP動(dòng)態(tài)分頁(yè)函數(shù),PHP開(kāi)發(fā)分頁(yè)必備啦
- php分頁(yè)代碼學(xué)習(xí)示例分享
相關(guān)文章
php實(shí)現(xiàn)統(tǒng)計(jì)郵件大小的方法
以下是對(duì)使用php實(shí)現(xiàn)統(tǒng)計(jì)郵件大小的方法進(jìn)行了分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08php簡(jiǎn)單處理XML數(shù)據(jù)的方法示例
這篇文章主要介紹了php簡(jiǎn)單處理XML數(shù)據(jù)的方法,結(jié)合具體實(shí)例形式分析了php對(duì)xml格式數(shù)據(jù)的簡(jiǎn)單載入、讀取、輸出等操作技巧,需要的朋友可以參考下2017-05-05PHP5中使用DOM控制XML實(shí)現(xiàn)代碼
PHP5中增強(qiáng)了XML的支持,使用DOM擴(kuò)展了XML操作的能耐。這些函數(shù)作為 PHP5 核心的一部分,無(wú)需被安裝即可使用。2010-05-05PHP排序算法之冒泡排序(Bubble Sort)實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP排序算法之冒泡排序(Bubble Sort)實(shí)現(xiàn)方法,參照大話數(shù)據(jù)結(jié)構(gòu)中的算法,結(jié)合實(shí)例形式較為詳細(xì)的分析了冒泡排序的原理與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-04-04js+php實(shí)現(xiàn)靜態(tài)頁(yè)面實(shí)時(shí)調(diào)用用戶登陸狀態(tài)的方法
這篇文章主要介紹了js+php實(shí)現(xiàn)靜態(tài)頁(yè)面實(shí)時(shí)調(diào)用用戶登陸狀態(tài)的方法,采用在靜態(tài)頁(yè)面中使用js調(diào)用php頁(yè)面從而實(shí)現(xiàn)用戶登錄狀態(tài)的實(shí)時(shí)調(diào)用功能,需要的朋友可以參考下2015-01-01php的GD庫(kù)imagettftext函數(shù)解決中文亂碼問(wèn)題
這篇文章主要介紹了php的GD庫(kù)imagettftext函數(shù)解決中文亂碼問(wèn)題,可通過(guò)將中文字符串轉(zhuǎn)為utf-8格式來(lái)解決,需要的朋友可以參考下2015-01-01