Board logo

標題: [教學] (PHP+IIS+MsSQL教學第29篇) 分頁瀏覽 [打印本頁]

作者: 小誌    時間: 2010-5-17 17:21     標題: (PHP+IIS+MsSQL教學第29篇) 分頁瀏覽

當我們資料筆數太多,若要一次將全部資料送交瀏覽器中來閱讀,不僅造成瀏覽器解譯時的沉重負擔,資料下載的時間也會拖的很長,因此,當資料量大時,將資料分成多次提取來閱讀是個相當不錯的做法。

本篇教學內容皆以SQL資料庫為使用對象,在下列附檔中有一個SQL資料庫「Student」,主資料檔Student.mdf、記錄檔Student.ldf,請您將檔案複製到您的硬碟裡並附加到SQL Server中,以方便您操作範例時使用。資料庫內的範例資料來自小誌參加技術士檢定考試的公開題庫資料,如有雷同存屬巧合。
[attach]566[/attach]

分頁基礎
「mssql_num_rows()」函數可用來獲知「mssql_quary()」函數中的資料記錄總筆數,其回傳值為一整數值,但小誌必須提醒您,利用「mssql_num_rows()」函數來獲知「mssql_quary()」函數中的資料記錄總筆數時,「mssql_num_rows()」函數必須讀全部記錄資料來計算筆數,所以比較消耗系統資源(小誌通常以SQL指令敘述來取得資料總筆數,而非以「mssql_num_rows()」函數來取得總筆數)。
例如:
  1. //取得資料錄數量
  2. $rowsnum=mssql_num_rows($datalist);
  3. //列印總筆數
  4. echo "資料總筆數 $rowsnum";
複製代碼
得知資料的總筆數後,要將資料錄分頁顯示之前,必須決定每一頁要有多少數量的資料記錄,而全部的資料記錄將要分成多少頁,例如下例中,我們將每10筆資料為一單位分頁顯示:
  1. //取得欄位數量
  2.       $fieldnum=mssql_num_fields($datalist);
  3.       //取得資料錄數量
  4.       $rowsnum=mssql_num_rows($datalist);
  5.       //計算總共有多少分頁
  6.       if (($rowsnum / 10) >intval($rowsnum / 10))
  7.        {
  8.         $TotalPage=intval($rowsnum / 10)+1;
  9.        }
  10.       else
  11.        {
  12.         $TotalPage=intval($rowsnum / 10);
  13.        }
複製代碼
先利用「mssql_num_rows()」函數取得總資料筆數,接著計算分頁的總頁數TotalPage,若資料錄數量無法整除,也就是不滿一頁的剩餘資料錄也要算一頁,例如:利用「mssql_num_rows()」函數告訴我們共讀取「通訊錄」資料表中479筆資料,我們設定顯示每頁10筆資料,則總分頁為「48」,47個滿頁加上一個只有9筆資料錄的分頁。
[attach]565[/attach]
(節錄)
  1. <?
  2.     $conn = mssql_connect("127.0.0.1", "sa", "12345");
  3.     if(@mssql_select_db("STUDENT", $conn))
  4.      {
  5.       //資料庫存在,建立SQL命令字串
  6.       $SQL="SELECT * FROM 通訊錄";
  7.       //將回傳結果存放於變數中
  8.       $datalist=mssql_query($SQL);
  9.       //取得欄位數量
  10.       $fieldnum=mssql_num_fields($datalist);
  11.       //取得資料錄數量
  12.       $rowsnum=mssql_num_rows($datalist);
  13.       //計算總共有多少分頁
  14.       if (($rowsnum / 10) >intval($rowsnum / 10))
  15.        {
  16.         $TotalPage=intval($rowsnum / 10)+1;
  17.        }
  18.       else
  19.        {
  20.         $TotalPage=intval($rowsnum / 10);
  21.        }      
  22. ?>
  23. <html>
  24. <head>
  25. <title>範例ex08_21</title>
  26. </head><body>
  27. <?="共$rowsnum 筆資料;共$TotalPage 張分頁";?>
  28. <center><table border=1 width=100%>
  29. //…略
複製代碼

作者: 小誌    時間: 2010-5-17 17:24

建立分頁選擇
為了讓使用者自己指定想要觀看的分頁內容,即在瀏覽器中附加參數傳遞給我們的程式:(ToPage參數值即使用者想觀看的分頁頁碼)
  1. http://localhost/php/ch8/ex08_22.php?ToPage=19
複製代碼
上例中「ToPage=19」即代表使用者想觀看的是第19個分頁的資料,因此我們就必須使用「mssql_data_seek()」函數,到指定頁數要顯示的第一筆資料錄上,也就是指定目前「作用中」資料錄要移到哪一個分頁的第一筆資料錄上來開始顯示內容。

由於使用者可在網址列自行輸入ToPage參數值,因此我們去需作一些預防措施,防止使用者指定了不正確的分頁頁碼:
  1. //決定開始顯示的分頁
  2. //若未指定分頁則預設顯示第一頁
  3. if (! isset($_REQUEST["ToPage"]))
  4. {
  5.   $GoPage=1;
  6. }
  7. //若指定分頁數小於1則預設顯示第一頁
  8. else if ($_REQUEST["ToPage"]<1)
  9. {
  10.   $GoPage=1;
  11. }
  12. //若指定指定的分頁超過總分頁數則顯示最後一頁
  13. else if ($_REQUEST["ToPage"]>$TotalPage)
  14. {
  15.   $GoPage=$TotalPage;
  16. }
  17. else
  18. {
  19. $GoPage=$_REQUEST["ToPage"];
  20. }
  21. //將作用中資料錄位置移到分頁的第一筆資料錄上來開始顯示內容
  22.   mssql_data_seek($datalist,($GoPage-1)*10);
複製代碼
分頁的數量很多,該如何讓使用者在網頁中點選呢?方法非常簡單,直接使用For迴圈來輸出頁碼連結即可:
  1. <?
  2. for ($I=1; $I<=$TotalPage; $I++)
  3. {
  4. //如果非正在顯示的分頁則建立頁碼連結
  5.    IF ($I != $GoPage )
  6.       {
  7.       $myURL=$_SERVER["PHP_SELF"] . "?ToPage=";
  8.       echo "<a href=" . $myURL . $I . ">" . $I . "</a>|" ;
  9.       }
  10. //如果是正在顯示的方頁則單純顯示頁碼
  11.    else
  12.       {
  13.       echo $I . "|" ;
  14.       }
  15. }
  16. ?>
複製代碼
上例中的「$_SERVER["PHP_SELF"]」,是利用_SERVER陣列變數物件取得環境變數「PHP_SELF」的值,也就是取得程式網頁本身的網址,將取得的網址資料加上ToPage參數的組合成超連結設定,就可以讓使用者點選而顯示使用者自己想觀看的分頁內容。

[attach]567[/attach]
  1. <?
  2.     $conn = mssql_connect("127.0.0.1", "sa", "12345");
  3.     if(@mssql_select_db("STUDENT", $conn))
  4.      {
  5.       //資料庫存在,建立SQL命令字串
  6.       $SQL="SELECT * FROM 通訊錄";
  7.       //將回傳結果存放於變數中
  8.       $datalist=mssql_query($SQL);
  9.       //取得欄位數量
  10.       $fieldnum=mssql_num_fields($datalist);
  11.       //取得資料錄數量
  12.       $rowsnum=mssql_num_rows($datalist);
  13.       //計算總共有多少分頁
  14.       if (($rowsnum / 10) >intval($rowsnum / 10))
  15.        {
  16.         $TotalPage=intval($rowsnum / 10)+1;
  17.        }
  18.       else
  19.        {
  20.         $TotalPage=intval($rowsnum / 10);
  21.        }
  22.       

  23. //決定開始顯示的分頁
  24. //若未指定分頁則預設顯示第一頁
  25. if (! isset($_REQUEST["ToPage"]))
  26. {
  27.   $GoPage=1;
  28. }
  29. //若指定分頁數小於1則預設顯示第一頁
  30. else if ($_REQUEST["ToPage"]<1)
  31. {
  32.   $GoPage=1;
  33. }
  34. //若指定指定的分頁超過總分頁數則顯示最後一頁
  35. else if ($_REQUEST["ToPage"]>$TotalPage)
  36. {
  37.   $GoPage=$TotalPage;
  38. }
  39. else
  40. {
  41. $GoPage=$_REQUEST["ToPage"];
  42. }
  43. //將作用中資料錄位置移到分頁的第一筆資料錄上來開始顯示內容
  44.   mssql_data_seek($datalist,($GoPage-1)*10);      
  45. ?>
  46. <html>
  47. <head>
  48. <title>範例ex08_22</title>
  49. </head><body>
  50. <?="共$rowsnum 筆資料;共$TotalPage 張分頁";?><p><center>

  51. <?
  52. for ($I=1; $I<=$TotalPage; $I++)
  53. {
  54. //如果非正在顯示的分頁則建立頁碼連結
  55.    IF ($I != $GoPage )
  56.       {
  57.       $myURL=$_SERVER["PHP_SELF"] . "?ToPage=";
  58.       echo "<a href=" . $myURL . $I . ">" . $I . "</a>|" ;
  59.       }
  60. //如果是正在顯示的方頁則單純顯示頁碼
  61.    else
  62.       {
  63.       echo $I . "|" ;
  64.       }
  65. }
  66. ?>

  67. <center><table border=1 width=100%>
  68. <?
  69. /**************列出欄位抬頭***************/
  70. echo "<tr>";     
  71.       for ($x=0 ;$x<$fieldnum;$x++)
  72.          {
  73.           echo "<td>" . mssql_field_name($datalist,$x) . "</td>";
  74.          }
  75. echo "</tr>";   
  76. /**************列出欄位資料***************/

  77.       for ($y=0;$y<10;$y++)  
  78.           {
  79.              //將資料錄轉換為欄位陣列集合
  80.             $fielddatas=mssql_fetch_array($datalist);
  81.              //輸出欄位資料
  82.              echo "<tr>";
  83.              for ($x=0;$x<$fieldnum;$x++)
  84.                 {
  85.                  echo "<td>" . $fielddatas[$x] . "</td>";
  86.                 }
  87.              echo "</tr>";  
  88.           }
  89. ?>
  90. <table></body>
  91. </html>
  92. <?
  93.      }
  94.     else
  95.      {
  96.       echo "資料庫不存在";
  97.      }
  98. ?>
複製代碼
自我評量(歡迎觀看本篇教學者,將自己所寫出的解答,回帖於本主題!!)
請試著修改上一個範例分頁選擇方式,改以表單方式讓使用者選取分頁,當使用者在下拉選單元件中選取要觀看的分頁項目,並按下表單中的「請跳頁」按鈕後,即顯示使用者指定的分頁內容:

[attach]568[/attach]




歡迎光臨 麻辣家族討論版版 (http://forum.twbts.com/)