麻辣家族討論版版's Archiver

小誌 發表於 2011-4-20 10:11

8-1-3 資料錄位置變換

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

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

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

小誌 發表於 2011-4-20 10:11

以範例ex08_06.php為例,我們可利用上述兩函數修改如下,讓程式只列印出1,3,5…等單數編號的資料錄(範例ex08_07.php):
ex08_07.php[code]<?
    $conn = mysql_connect("localhost", "root", "12345a");
    if(@mysql_select_db("STUDENTS", $conn))
     {
//指定提取資料的校對字元表
mysql_query("set character set big5");
      //資料庫存在,建立SQL命令字串
      $SQL="SELECT * FROM transcript";
      //將回傳結果存放於變數中
      $datalist=mysql_query($SQL);
      //取得欄位數量
      $fieldnum=mysql_num_fields($datalist);
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<title>範例ex08_07</title>
</head>
<center><table border=1 width=100%>
<?
/**************列出欄位抬頭***************/
echo "<tr>";     
      for ($x=0 ;$x<$fieldnum;$x++)
         {
          echo "<td>" . mysql_field_name($datalist,$x) . "</td>";
         }
echo "</tr>";   
/**************列出欄位資料***************/
      //取得資料錄數量
      $rowsnum=mysql_num_rows($datalist);
      for ($y=0;$y<$rowsnum;$y+=2)  
          {
            if($y<=$rowsnum):
             //變換作用中資料錄位置
            mysql_data_seek($datalist,$y);
             //將資料錄轉換為欄位陣列集合
            $fielddatas=mysql_fetch_array($datalist);
             //輸出欄位資料
             echo "<tr>";
             for ($x=0;$x<$fieldnum;$x++)
                {
                 echo "<td>" . $fielddatas[$x] . "</td>";
                }
             echo "</tr>";  
            endif;
          }
?>
<table></body>
</html>
<?
     }
    else
     {
      echo "資料庫不存在";
     }
?>[/code]

頁: [1]

麻辣家族討論版版為 麻辣學園 網站成員  由 昱得資訊工作室 © Since 1993 所提供