国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

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

2020-01-18 23:40:59
字體:
來源:轉載
供稿:網友

這兩個函數,返回的都是一個數組,區別就是第一個函數返回的數組是只包含值,我們只能$row[0],
$row[1],這樣以數組下標來讀取數據,而mysql_fetch_array()返回的數組既包含第一種,也包含鍵值
對的形式,我們可以這樣讀取數據,(假如數據庫的字段是 username,passwd):
  $row['username'], $row['passwd']

  而且,如果用($row as $kay => $value)來操作的話,還以直接取得數據庫的字段名稱。
  更主要的是mysqli是php5提供的新函數庫,(i)表示改進,其執行速度更快.

例如:

<?php//連接到本地mysql數據庫,選擇test為操作庫$mysqli = mysqli_connect("localhost", "root", "","test", 3306);//用mysql_query函數從user表里讀取數據$result = mysqli_query($mysqli, "SELECT * FROM userinfo");while($row = mysqli_fetch_array($result))//通過循環讀取數據內容{?><tr>  <td align="center" height="19"><?php echo $row["ID"]?></td>  <td align="center"><?php echo $row["Name"]?></td>  <td align="center"><?php echo $row["Detail"]?></td></tr><?php}//關閉對數據庫的連接mysqli_free_result($result);mysqli_close($mysqli);*/?>

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。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 贵定县| 萝北县| 波密县| 西藏| 揭阳市| 睢宁县| 玉田县| 武宁县| 永嘉县| 章丘市| 武宣县| 芦山县| 普定县| 赤峰市| 固安县| 航空| 阳春市| 定安县| 徐闻县| 凤阳县| 英吉沙县| 云安县| 犍为县| 交口县| 衡阳县| 久治县| 万荣县| 南昌县| 卢氏县| 苍山县| 滕州市| 航空| 乐昌市| 东山县| 陈巴尔虎旗| 台安县| 逊克县| 阿勒泰市| 潢川县| 耒阳市| 镶黄旗|