国产激情久久久久影院小草_国产91高跟丝袜_99精品视频99_三级真人片在线观看

PHP分頁效率加強(qiáng)版

時間:2024-09-12 16:24:31 PHP 我要投稿
  • 相關(guān)推薦

PHP分頁效率加強(qiáng)版

  這里僅展示出設(shè)計(jì)思路,具體安全問題,是否同步更新等可根據(jù)具體需求添加修改:

  以前人們常用的PHP分頁技術(shù),通常都需要先統(tǒng)計(jì)出數(shù)據(jù)庫中總信息條數(shù)才能判斷出總頁數(shù)并對其進(jìn)行分頁,,也就是說,每次分頁要對數(shù)據(jù)庫進(jìn)行兩次調(diào)用,在面臨大數(shù)據(jù)量,高并發(fā)查詢情況下是很不效率的,曾經(jīng)一直為這個問題煩惱但都沒想到合適的解決方法,今天突然在睡夢中 遇見奇跡...具體分析原理如下:(紅色部分為優(yōu)化后的區(qū)別,思路采用最原始的代碼書寫,為了照顧新人)

  原始分頁技術(shù):包括許多開源程序也在使用的技術(shù);

  一般都是對數(shù)據(jù)庫信息進(jìn)行統(tǒng)計(jì),然后調(diào)用分頁類,進(jìn)行分頁,,每次都要經(jīng)過2次數(shù)據(jù)庫查詢操作

  例(原始分頁技術(shù)): 每次都要進(jìn)行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"];//每次翻頁都要進(jìn)行 總信息條數(shù) 的數(shù)據(jù)庫查詢操作

  $pagesize=10; //每頁顯示數(shù)量

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

  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è)當(dāng)前頁為 URL.PHP

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

  }

  //優(yōu)化后的分頁技術(shù)(只需在第一次調(diào)用時進(jìn)行信息統(tǒng)計(jì)即可)

  if(isset($_GET["total"])){ //只需要進(jìn)行一次總信息條數(shù)的統(tǒng)計(jì)即可

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

  //以后的的總信息數(shù)量通過GET傳遞即可,節(jié)省了1/2的數(shù)據(jù)庫負(fù)荷,,,,

  }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;//當(dāng)前頁

  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è)當(dāng)前頁為 URL.PHP

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

  }

【PHP分頁效率加強(qiáng)版】相關(guān)文章:

分頁word表格怎么修改02-15

基于ajax實(shí)現(xiàn)無刷新分頁的方法10-15

EXCEL取消分頁符的操作方法05-29

關(guān)于php面試寶典及PHP面試技巧08-16

Word中分節(jié)符和分頁符的區(qū)別02-21

淺談如何解決網(wǎng)站分頁SEO問題06-10

PHP的壓縮函數(shù)06-21

php高級教程01-23

如何學(xué)好PHP知識09-20

 PHP的基礎(chǔ)編程與應(yīng)用10-16