Board logo

標題: 8-1-3 資料錄位置變換 [打印本頁]

作者: 小誌    時間: 2011-4-20 10:11     標題: 8-1-3 資料錄位置變換

8-1-3   資料錄位置變換
在上一小節中,我們已知道:利用「mysql_featch_array()」函數取得一筆資料錄資料後,則「作用中」的資料錄位置會自動移到下一筆尚未提取資料的資料錄位置上,其實還有一個快速變換作用中資料錄位置的函數:mysql_data_seek():
mysql_data_seek() 函數
  1. int mysql_data_seek ( int result_identifier, int row_number)
複製代碼
result_identifier、row_number都是必要參數,result_identifier參數值可為mysql_db_query()、mysql_query()、mysql_list_tables()、mysql_list_dbs()等函數所回傳的結果ID。

當變換作用中資料錄位置成功回傳true值,反之,回傳false值;例如,快速變換作用中資料錄位置到第一筆資料錄上:
  1. $datalist=mysql_query($SQL);
  2. mysql_data_seek($datalist,0);
複製代碼
請注意:資料錄的位置編號是從0開始!

若我們想知到共有多少筆資料記錄可提取,則「mysql_num_rows()」函數可以告訴我們:
mysql_num_rows() 函數
  1. int mysql_num_rows ( int result_ identifier)
複製代碼
result_identifier是必要參數,參數值可為mysql_db_query()、mysql_query()、mysql_list_tables()、mysql_list_dbs()等函數所回傳的結果ID。
例如:
  1. //資料庫存在,建立SQL命令字串
  2. $SQL="SELECT * FROM transcript";
  3. //將回傳結果存放於變數中
  4. $datalist=mysql_query($SQL);
  5. //取得資料錄筆數
  6. $x=mysql_num_rows($datalist);
  7. echo "共 $X 筆資料記錄";
複製代碼

作者: 小誌    時間: 2011-4-20 10:11

以範例ex08_06.php為例,我們可利用上述兩函數修改如下,讓程式只列印出1,3,5…等單數編號的資料錄(範例ex08_07.php):
ex08_07.php
  1. <?
  2.     $conn = mysql_connect("localhost", "root", "12345a");
  3.     if(@mysql_select_db("STUDENTS", $conn))
  4.      {
  5. //指定提取資料的校對字元表
  6. mysql_query("set character set big5");
  7.       //資料庫存在,建立SQL命令字串
  8.       $SQL="SELECT * FROM transcript";
  9.       //將回傳結果存放於變數中
  10.       $datalist=mysql_query($SQL);
  11.       //取得欄位數量
  12.       $fieldnum=mysql_num_fields($datalist);
  13. ?>
  14. <html>
  15. <head>
  16. <meta http-equiv="Content-Type" content="text/html; charset=big5">
  17. <title>範例ex08_07</title>
  18. </head>
  19. <center><table border=1 width=100%>
  20. <?
  21. /**************列出欄位抬頭***************/
  22. echo "<tr>";     
  23.       for ($x=0 ;$x<$fieldnum;$x++)
  24.          {
  25.           echo "<td>" . mysql_field_name($datalist,$x) . "</td>";
  26.          }
  27. echo "</tr>";   
  28. /**************列出欄位資料***************/
  29.       //取得資料錄數量
  30.       $rowsnum=mysql_num_rows($datalist);
  31.       for ($y=0;$y<$rowsnum;$y+=2)  
  32.           {
  33.             if($y<=$rowsnum):
  34.              //變換作用中資料錄位置
  35.             mysql_data_seek($datalist,$y);
  36.              //將資料錄轉換為欄位陣列集合
  37.             $fielddatas=mysql_fetch_array($datalist);
  38.              //輸出欄位資料
  39.              echo "<tr>";
  40.              for ($x=0;$x<$fieldnum;$x++)
  41.                 {
  42.                  echo "<td>" . $fielddatas[$x] . "</td>";
  43.                 }
  44.              echo "</tr>";  
  45.             endif;
  46.           }
  47. ?>
  48. <table></body>
  49. </html>
  50. <?
  51.      }
  52.     else
  53.      {
  54.       echo "資料庫不存在";
  55.      }
  56. ?>
複製代碼





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