程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql_fetch_row()與mysql_fetch_array()的使用介紹

mysql_fetch_row()與mysql_fetch_array()的使用介紹

編輯:MySQL綜合教程

mysql_fetch_array --從結果集中取得一行作為關聯數組,或數字數組,或二者兼有

說明array mysql_fetch_array ( resource result [, int result_type])

返回根據從結果集取得的行生成的數組,如果沒有更多行則返回 FALSE。
mysql_fetch_array() 是 mysql_fetch_row() 的擴展版本。除了將數據以數字索引方式儲存在數組中之外,還可以將數據作為關聯索引儲存,用字段名作為鍵名。

如果結果中的兩個或以上的列具有相同字段名,最後一列將優先。要訪問同名的其它列,必須用該列的數字索引或給該列起個別名。對有別名的列,不能再用原來的列名訪問其內容(本例中的 'field')。
例子 1. 相同字段名的查詢
復制代碼 代碼如下:
select table1.field as foo, table2.field as bar from table1, table2

有一點很重要必須指出,用 mysql_fetch_array() 並不明顯 比用 mysql_fetch_row() 慢,而且還提供了明顯更多的值。

mysql_fetch_array() 中可選的第二個參數 result_type 是一個常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。本特性是 PHP 3.0.7 起新加的。本參數的默認值是 MYSQL_BOTH。

如果用了 MYSQL_BOTH,將得到一個同時包含關聯和數字索引的數組。用 MYSQL_ASSOC 只得到關聯索引(如同 mysql_fetch_assoc()那樣),用 MYSQL_NUM 只得到數字索引(如同 mysql_fetch_row()那樣)。

注: 該函數返回的字段名是大小寫敏感的。

例子 2. mysql_fetch_array 使用 MYSQL_NUM
復制代碼 代碼如下:
<?php
   mysql_connect("localhost", "mysql_user", "mysql_password") or
       die("Could not connect: " . mysql_error());
   mysql_select_db("mydb");

   $result = mysql_query("SELECT id, name FROM mytable");

   while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
       printf ("ID: %s  Name: %s", $row[0], $row[1]);
   }

   mysql_free_result($result);
?> 

例子 3. mysql_fetch_array 使用 MYSQL_ASSOC
復制代碼 代碼如下:
<?php
   mysql_connect("localhost", "mysql_user", "mysql_password") or
       die("Could not connect: " . mysql_error());
   mysql_select_db("mydb");

   $result = mysql_query("SELECT id, name FROM mytable");

   while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
       printf ("ID: %s  Name: %s", $row["id"], $row["name"]);
   }
   mysql_free_result($result);
?>

例子 4. mysql_fetch_array 使用 MYSQL_BOTH
復制代碼 代碼如下:
<?php
   mysql_connect("localhost", "mysql_user", "mysql_password") or
       die("Could not connect: " . mysql_error());
   mysql_select_db("mydb");

   $result = mysql_query("SELECT id, name FROM mytable");

   while ($row = mysql_fetch_array($result, MYSQL_BOTH)) {
       printf ("ID: %s  Name: %s", $row[0], $row["name"]);
   }
   mysql_free_result($result);
?>

參見 mysql_fetch_row() 和 mysql_fetch_assoc
mysql_fetch_row -- 從結果集中取得一行作為枚舉數組

說明
array mysql_fetch_row ( resource result)
返回根據所取得的行生成的數組,如果沒有更多行則返回 FALSE。
mysql_fetch_row() 從和指定的結果標識關聯的結果集中取得一行數據並作為數組返回。每個結果的列儲存在一個數組的單元中,偏移量從 0 開始。
依次調用 mysql_fetch_row() 將返回結果集中的下一行,如果沒有更多行則返回 FALSE。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved