復雜檢索數據並分頁顯示的處理方法

系統標題:復雜檢索數據並分頁顯示的處理方法
系統功能:利用臨時表檢索數據庫數據,然後分頁顯示的方法:
處理方法:采用臨時表存放數據中間結果,根據中間結果顯示數據
          數據的顯示采用隔行的方式處理
處理優點:對於復雜的查詢,特別是涉及到多表的數據查詢,如果直接使用查詢條件,系統的
          開銷將很大,利用臨時表把數據先保存,然後處理。這樣對數據庫的查詢隻要開銷一次。
使用方法:隻要把連接數據庫的用戶信息和數據表改變即可使用
        
<?
  //連接數據庫
  $dbh =  MySQL(和PHP搭配之最佳組合)_connect(localhost:3306,root,);
  MySQL(和PHP搭配之最佳組合)_select_db(test);  

  //把數據檢索的結果保存到臨時表中
   $ls_sql  = create temporary table temps ;
   $ls_sql .= select lk_title,lk_link from  lk_t_content ;
   $ls_sql .= ” where lk_title like %”.$searchcontent.”% “;
   $res = MySQL(和PHP搭配之最佳組合)_query($ls_sql, $dbh);
  
  //得到檢索數據的總數   
   $ls_sql = select count(*) as rcnt_con from temps ;
   $res = MySQL(和PHP搭配之最佳組合)_query($ls_sql, $dbh);
   $rcon = $row[“rcnt_con”];   

   $pages=ceil($rcon / 20); //$pages變量現在總的頁數   
   if (empty($offset))  {
       $offset=1;   
       $curline = 0;
    } else
      $curline = ($offset – 1) * 20;
   //打印表頭
   print <table width=”100%” border=”0″>;
   print <tr class=”text”> <td width=”50%”>  <p align=”center”>;
   if ($offset <> 1) { //如果偏移量是0,不顯示前一頁的鏈接   
     $newoffset=$offset – 1;   
     print “<a href=$php(做為現在的主流開發語言)_SELF?offset=$newoffset>前一頁</a>”;   
   }  else {
     print “前一頁”;
     print ”   “;
   }
  //顯示所有的頁數   
  for ($i=1; $i <= $pages; $i++)  {
    $temps = “<a href=”.$php(做為現在的主流開發語言)_SELF.?offset=.$i.”>”.$i.”</a>”;
    print $temps;   
    print ”   “;
  }   
  //檢查是否是最後一頁   
  if ($pages!=0 && $offset!=$pages)  {
     $newoffset=$offset+1;   
     print “<a href=$php(做為現在的主流開發語言)_SELF?offset=$newoffset>下一頁</a>”;   
  }  else print “下一頁”;
  print </p> </td>;

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *