色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

這里僅展示出設(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ù)庫查詢
復(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技術(shù)PHP分頁效率終結(jié)版(推薦),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 长宁县| 沾化县| 荔波县| 西宁市| 新营市| 崇阳县| 光山县| 新建县| 仪陇县| 页游| 恩施市| 库车县| 隆林| 洪江市| 桑日县| 四子王旗| 介休市| 宁都县| 兴宁市| 营山县| 宝鸡市| 英吉沙县| 大宁县| 随州市| 昔阳县| 裕民县| 红安县| 旬阳县| 昌江| 松桃| 儋州市| 临清市| 清远市| 武夷山市| 浦北县| 大连市| 成都市| 津南区| 宜宾县| 新营市| 盈江县|