PHP如何使用MySQLi中的MySQLI_result物件操作
在之前我們就已經接觸過MYSQLI_result相關的內容。它其實就是一個查詢的結果集。不過在PDO中,一般透過query()或PDOStatement物件查詢後就會回傳結果。但在MySQLi中,會把查詢到的結果也放入一個物件中,這就是MySQLI_result物件。
MySQLI_result 物件屬性
首先,我們要透過一段查詢來取得一個 MySQLI_result 物件。
$stmt = $mysqli->prepare("select * from zyblog_test_user where username = 'kkk'"); $stmt->execute(); // 执行语句 $result = $stmt->get_result(); var_dump($result); // object(mysqli_result)#3 (5) { // ["current_field"]=> // int(0) // ["field_count"]=> // int(4) // ["lengths"]=> // NULL // ["num_rows"]=> // int(7) // ["type"]=> // int(0) // }
如果使用的 MYSQLI_STMT 的話,直接在 execute() 方法執行查詢語句之後,就可以透過 get_result() 方法取得一個 MySQLI_result 物件。
在這個物件中,我們可以看到有 current_field 目前欄位 、 field_count 欄位數量 、 lengths 欄位長度 、 num_rows 行數 、 type 這些屬性內容。不少同學會發現,current_field 和lengths 好像沒有什麼實際的內容,其實這兩個屬性是需要在特定操作下才會顯示內容的,比如lengths 是要在fetch() 結果集之後才會有訊息的。
$result->fetch_array(); var_dump($result); // …… // …… // ["lengths"]=> // array(4) { // [0]=> // int(0) // [1]=> // int(3) // [2]=> // int(3) // [3]=> // int(2) // } // …… // ……
而 current_field 屬性的內容我們將在下面遍歷查看字段資訊的時候再展示它的內容。
查詢結果集取得
MySQLI_result 物件的可見屬性中,我們只能看到上面的那些資訊。對於我們的業務開發來說其實用處不大,除了num_rows 可以用來根據行數判斷查詢是否有結果之外,更重要的是我們要獲取到結果集中的數據信息,這時就需要使用其它的函數來進行數據的獲取了。
取得全部結果集
var_dump($result->fetch_all()); // array(7) { // [0]=> // array(4) { // [0]=> // int(42) // [1]=> // string(3) "kkk" // [2]=> // string(3) "666" // [3]=> // string(2) "k6" // } // …… // …… $result->data_seek(0); var_dump($result->fetch_all(MYSQLI_ASSOC)); // array(7) { // [0]=> // array(4) { // ["id"]=> // int(42) // ["username"]=> // string(3) "kkk" // ["password"]=> // string(3) "666" // ["salt"]=> // string(2) "k6" // } // …… // ……
fetch_all() 方法就是用來取得全部的資料集內的數據,並以數組的形式返回,它可以指定返回的格式,預設情況下是MYSQLI_NUM 這種陣列下標的形式,和PDO 類似,我們直接指定為MySQLI_ASSOC 就可以傳回鍵名形式的資料內容。
data_seek() 方法是移動結果集的下標。當我們取得或使用後面要介紹的方法循環遍歷完成一次結果集之後,再次遍歷的話它的遊標已經處於最後一位的,這樣是無法獲取資料的。在上面的程式碼中,我們就是將遊標兩次回到 0 下標的位置,也就是最初始的位置,這樣我們就可以重複地操作這一個結果集了。
取得普通結果集
如果要一行一行資料的獲取,我們就可以使用各種形式的結果集資料取得方式。
var_dump($result->fetch_array()); // array(8) { // [0]=> // int(42) // ["id"]=> // int(42) // [1]=> // string(3) "kkk" // ["username"]=> // string(3) "kkk" // [2]=> // string(3) "666" // ["password"]=> // string(3) "666" // [3]=> // string(2) "k6" // ["salt"]=> // string(2) "k6" // } var_dump($result->fetch_array(MYSQLI_ASSOC)); // array(4) { // ["id"]=> // int(43) // ["username"]=> // string(3) "kkk" // ["password"]=> // string(3) "666" // ["salt"]=> // string(2) "k6" // }
使用fetch_array() 就是獲取下一行的結果資料並以數組的形式返回,同樣它也可以指定返回結果集的格式,和fetch_all() 是類似的,只不過它是只獲取下一行而不是全部的資料集,而且它的參數預設是傳回的MYSQLI_BOTH ,也就是數字下標和鍵名下標同時回傳結果。
另外還有一個 fetch_assoc() 方法,直接就是傳回 MYSQLI_ASSOC 格式的數據,這個方法不需要任何參數,它可以看成是 fetch_array(MYSQLI_ASSOC) 這種使用方式的一個封裝。
var_dump($result->fetch_assoc()); // array(4) { // ["id"]=> // int(42) // ["username"]=> // string(3) "kkk" // ["password"]=> // string(3) "666" // ["salt"]=> // string(2) "k6" // }
而另一個方法 fetch_row() ,則可以看成是和 fetch_array(MYSQLI_NUM) 相似的一個方法。它其實就是預設指定為 MySQLI_NUM 的結構回傳方式。
var_dump($result->fetch_row()); // array(4) { // [0]=> // int(43) // [1]=> // string(3) "kkk" // [2]=> // string(3) "666" // [3]=> // string(2) "k6" // }
取得物件結果集
取得物件結果集其實和 PDO 中的相關功能也是類似的,它就是將結果直接放到一個類別中,並實例化回傳一個物件。
ar_dump($result->fetch_object()); // object(stdClass)#4 (4) { // ["id"]=> // int(42) // ["username"]=> // string(3) "kkk" // ["password"]=> // string(3) "666" // ["salt"]=> // string(2) "k6" // }
在這裡我們沒有指定類,所以它使用的是 stdClass 來傳回的物件結構。我們也可以指定一個類,並且可以為這個類別的建構子傳遞參數,這一點也和 PDO 中的相關函數一樣。
class User { public function __construct() { print_r(func_get_args()); } } var_dump($result->fetch_object('User', [1, 2, 3])); // Array // ( // [0] => 1 // [1] => 2 // [2] => 3 // ) // object(User)#4 (4) { // ["id"]=> // int(42) // ["username"]=> // string(3) "kkk" // ["password"]=> // string(3) "666" // ["salt"]=> // string(2) "k6" // }
查詢結果集欄位資訊取得
接下來我們再看看 MySQLI_result 物件中的欄位相關資訊的取得。我們可以直接取得到目前查詢的結果集中的所有欄位資訊。
while ($finfo = $result->fetch_field()) { var_dump($result->current_field); var_dump($finfo); } // int(1) // object(stdClass)#4 (13) { // ["name"]=> // string(2) "id" // ["orgname"]=> // string(2) "id" // ["table"]=> // string(16) "zyblog_test_user" // ["orgtable"]=> // string(16) "zyblog_test_user" // ["def"]=> // string(0) "" // ["db"]=> // string(9) "blog_test" // ["catalog"]=> // string(3) "def" // ["max_length"]=> // int(0) // ["length"]=> // int(11) // ["charsetnr"]=> // int(63) // ["flags"]=> // int(49667) // ["type"]=> // int(3) // ["decimals"]=> // int(0) // } // int(2) // object(stdClass)#5 (13) { // ["name"]=> // string(8) "username" // ["orgname"]=> // string(8) "username" // …… // ……
在這段程式碼中,我們查看了 MySQLI_result 物件的 current_field 屬性訊息,可以看出,它指出的就是目前位於哪個欄位的下標。
欄位的資訊非常詳細,這些屬性的鍵名也很直觀,這裡就不作詳細的說明了。
$result->field_seek(1); while ($finfo = $result->fetch_field()) { var_dump($finfo); } // object(stdClass)#5 (13) { // ["name"]=> // string(8) "username" // ["orgname"]=> // string(8) "username"
我們同樣也可以透過 field_seek() 方法來移動欄位遍歷的遊標。在這裡我們將遊標移到 1 ,就會從第二個 username 欄位開始遍歷。
var_dump($result->fetch_fields()); // array(4) { // [0]=> // object(stdClass)#5 (13) { // ["name"]=> // string(2) "id" // ["orgname"]=> // string(2) "id" // ["table"]=> // string(16) "zyblog_test_user" // ["orgtable"]=> // string(16) "zyblog_test_user" // ["def"]=> // string(0) "" // ["db"]=> // string(9) "blog_test" // ["catalog"]=> // string(3) "def" // ["max_length"]=> // int(0) // ["length"]=> // int(11) // ["charsetnr"]=> // int(63) // ["flags"]=> // int(49667) // ["type"]=> // int(3) // ["decimals"]=> // int(0) // } // [1]=> // object(stdClass)#4 (13) { // ["name"]=> // string(8) "username" var_dump($result->fetch_field_direct(2)); // object(stdClass)#7 (13) { // ["name"]=> // string(8) "password" // ["orgname"]=> // string(8) "password" // ["table"]=> // string(16) "zyblog_test_user" // ["orgtable"]=> // string(16) "zyblog_test_user" // ["def"]=> // string(0) "" // ["db"]=> // string(9) "blog_test" // ["catalog"]=> // string(3) "def" // ["max_length"]=> // int(3) // ["length"]=> // int(765) // ["charsetnr"]=> // int(33) // ["flags"]=> // int(0) // ["type"]=> // int(253) // ["decimals"]=> // int(0) // }
fetch_fields() 方法和 fetch_all() 是類似的,它就是要取得全部的欄位資訊。而 fetch_field_direct() 則是根據參數來取得指定下標的欄位資訊。
总结
至此,MySQLi 相关扩展的学习我们也就告一段落了,其它的一些类和函数比如 MySQLI_Driver 、 MySQLI_Exception 之类的内容大家可以自行查阅相关的文档,内容都不是很多。MySQLI_Driver 对象可以帮助我们指定当前驱动的报错形式,之前的文章中我们也已经接触过。
总体来说,整个 PHP 中和 MySQL 打交道的官方扩展我们就已经全部学习完了,PDO 和 MYSQLi 这两个扩展大家更主要的还是要掌握它们的区别和联系。在实际的业务开发中 PDO 还是会使用得更多,但 MySQLi 也绝不是能够完全忽略的,多多动手尝试学习吧。
测试代码:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202009/source/9.PHP中的MySQLi扩展学习(六)MySQLI_result对象操作.php
推荐学习:php视频教程
以上是PHP如何使用MySQLi中的MySQLI_result物件操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。
