PHP之mysql_fetch系列函數詳解

來源:互聯網
上載者:User
本文主要介紹了PHP中操作MySQL的mysql_fetch函數的常見用法教程,文中提到了其下fetch_array和mysql_fetch_row以及mysql_fetch_object函數的使用。希望對大家有所協助。

mysql_fetch_* 列函數
mysql_fetch_* 列函數的主要功能是從查詢返回的結果集中取得相關的查詢結果,主要包括:

  • mysql_fetch_array():從結果集中取得一行作為關聯陣列或索引數組,或二者兼有

  • mysql_fetch_row():從結果集中取得一行作為枚舉數組

  • mysql_fetch_assoc():從結果集中取得一行作為關聯陣列

  • mysql_fetch_object():從結果集中取得一行作為對象

  • mysql_fetch_field():從結果集中取得欄位資訊並作為對象返回

  • mysql_fetch_lengths():取得結果集中取得一行每個欄位內容輸出的長度

  • mysql_fetch_array()

mysql_fetch_array() 函數用於從結果集中取得一行作為關聯陣列或索引數組,或二者兼有。成功返回一個數組,否則返回 FALSE 。

文法:


array mysql_fetch_array( resource result [, int result_type] )


參數說明:

  • result:查詢函數(如 mysql_query)返回的資料集資源

  • result_type:可選常量,標明數組結果類型,可接受值如下:

  • MYSQL_BOTH:預設,得到一個同時包含關聯和數字索引的數組,用欄位名作為鍵名

  • MYSQL_ASSOC:只得到關聯索引的數組

  • MYSQL_NUM:只得到數字索引的數組

例子 1 ,使用 MYSQL_NUM :


<?php$conn = @mysql_connect("localhost","root","root123");if (!$conn){ die("串連資料庫失敗:" . mysql_error());}mysql_select_db("test", $conn);mysql_query("set character set 'gbk'");$result = mysql_query("SELECT uid,username FROM user");while($row = mysql_fetch_array($result, MYSQL_NUM)){ echo "使用者ID:".$row[0]."<br />"; echo "使用者名稱:".$row[1]."<br />";}?>


瀏覽器輸出:


使用者ID:1使用者名稱:admin使用者ID:2使用者名稱:小明使用者ID:3使用者名稱:Jack使用者ID:4使用者名稱:小王


例子 2 ,使用 MYSQL_ ASSOC :


//重複代碼省略$result = mysql_query("SELECT uid,username FROM user");while($row = mysql_fetch_array($result, MYSQL_ ASSOC)){ echo "使用者ID:".$row['uid']."<br />"; echo "使用者名稱:".$row['username']."<br />";}


瀏覽器輸出內容同上。
當使用 MYSQL_BOTH 或省略該參數是,將同時具有 MYSQL_NUM 與 MYSQL_ ASSOC 的特性。
說明
本函數返回的欄位名作為數組索引值是區分大小寫
用 mysql_fetch_array() 並不明顯 比用 mysql_fetch_row() 慢,而且還提供了明顯更多的值
該函數只從當前資料指標取得一行資料作為結果返回,如果執行過一次,會將資料指標指向下一列資料
如果要取得多行或者全部資料,需要使用迴圈結構將資料逐行取出
如果結果中的兩個或以上的列具有相同欄位名,最後一列將優先。要訪問同名的其它列,必須用該列的數字索引或給該列起個別名


mysql_fetch_row()
PHP 的 MySQL 操作函數 mysql_fetch_row() 用於從結果集中取得一行作為枚舉數組。成功返回一個數組,否則返回 FALSE 。
文法:


array mysql_fetch_row( resource result )


該函數表現與 mysql_fetch_array( resource result, MYSQL_NUM ) 一致,請參考mysql_fetch_array() 函數用法,在此不在贅述。

mysql_fetch_object()
PHP 操作 MySQL 的函數 mysql_fetch_object() 用於從結果集中取得一行作為對象,成功返回一個對象,否則返回 FALSE 。
文法:


object mysql_fetch_object( resource result )


例子:


<?php$conn = @mysql_connect("localhost","root","root123");if (!$conn){ die("串連資料庫失敗:" . mysql_error());}mysql_select_db("test", $conn);mysql_query("set character set 'gbk'");$result = mysql_query("SELECT uid,username FROM user");while($row = mysql_fetch_object($result)){ echo "使用者ID:".$row->uid."<br />"; echo "使用者名稱:".$row->username."<br />";}?>


瀏覽器輸出:


使用者ID:1使用者名稱:admin使用者ID:2使用者名稱:小明使用者ID:3使用者名稱:Jack使用者ID:4使用者名稱:小王


相關推薦:

php 資料庫類 適用於 mysql sql service

PHP 資料庫操作 mysqli

超輕的 PHP 資料庫工具包

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.