PHP中mysql_fetch_row()、mysql_fetch_assoc()和mysql_fetch_array()的聯系


總是記不住或者混淆mysql_fetch_row()mysql_fetch_assoc()mysql_fetch_array()這三個函數的朋友們注意了,今天我在這里給大家總結一下他們之間的關系,希望能對大家有所幫助。

1.mysql_fetch_row() -- 從結果集中取得一行作為枚舉數組

說明  array mysql_fetch_row ( resource result)

返回根據所取得的行生成的數組,如果沒有更多行則返回 FALSE

mysql_fetch_row() 從和指定的結果標識關聯的結果集中取得一行數據並作為數組返回。每個結果的列儲存在一個數組的單元中,偏移量從 0 開始。

依次調用 mysql_fetch_row() 將返回結果集中的下一行,如果沒有更多行則返回 FALSE

2.mysql_fetch_assoc() -- 從結果集中取得一行作為關聯數組

說明  array mysql_fetch_assoc ( resource result)

返回根據從結果集取得的行生成的關聯數組,如果沒有更多行,則返回 false

mysql_fetch_assoc()將數據作為關聯索引儲存,用字段名作為鍵名。如果結果中的兩個或以上的列具有相同字段名,最后一列將優先。要訪問同名的其它列,必須用該列的數字索引或給該列起個別名。對有別名的列,不能再用原來的列名訪問其內容。

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

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

返回根據從結果集取得的行生成的數組,如果沒有更多行則返回 FALSE

mysql_fetch_array() mysql_fetch_row() 的擴展版本。除了將數據以數字索引方式儲存在數組中之外,還可以將數據作為關聯索引儲存,用字段名作為鍵名。

如果結果中的兩個或以上的列具有相同字段名,最后一列將優先。要訪問同名的其它列,必須用該列的數字索引或給該列起個別名。對有別名的列,不能再用原來的列名訪問其內容。

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

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

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

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM