国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > PHP > 正文

PHP分頁(yè)效率終結(jié)版(推薦)

2024-05-04 23:11:44
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這里僅展示出設(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ā)查詢(xún)情況下是很不效率的,曾經(jīng)一直為這個(gè)問(wèn)題煩惱但都沒(méi)想到合適的解決方法,今天突然在睡夢(mèng)中 遇見(jiàn)奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書(shū)寫(xiě),為了照顧新人)
原始分頁(yè)技術(shù):包括許多開(kāi)源程序也在使用的技術(shù);
一般都是對(duì)數(shù)據(jù)庫(kù)信息進(jìn)行統(tǒng)計(jì),然后調(diào)用分頁(yè)類(lèi),進(jìn)行分頁(yè),,每次都要經(jīng)過(guò)2次數(shù)據(jù)庫(kù)查詢(xún)操作
例(原始分頁(yè)技術(shù)): 每次都要進(jìn)行2次數(shù)據(jù)庫(kù)查詢(xún)

復(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ù)查詢(xún)操作
$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ù)查詢(xún)操作
  $info=mysql_fetch_array($sql);
   do{
    ...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類(lèi)
$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ù)查詢(xún)操作
  $info=mysql_fetch_array($sql);
   do{
    ...............
}while($info=mysql_fetch_array($sql));
include("page_class.php");//調(diào)用分頁(yè)類(lèi)
   $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地址
}

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 临漳县| 肃宁县| 临潭县| 兴化市| 宣威市| 彝良县| 永川市| 保德县| 抚宁县| 教育| 宜兴市| 柯坪县| 洞头县| 广昌县| 连州市| 临潭县| 柳江县| 甘孜县| 康马县| 理塘县| 福鼎市| 古蔺县| 浦江县| 弥渡县| 庐江县| 福清市| 油尖旺区| 长武县| 崇州市| 安吉县| 彭阳县| 乌兰浩特市| 扬中市| 廉江市| 哈巴河县| 兴宁市| 远安县| 苗栗市| 古田县| 崇左市| 唐山市|