溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP怎么使用MySQLi中的MySQLI_result對象操作

發(fā)布時(shí)間:2021-07-02 09:25:51 來源:億速云 閱讀:194 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“PHP怎么使用MySQLi中的MySQLI_result對象操作”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“PHP怎么使用MySQLi中的MySQLI_result對象操作”這篇文章吧。

在之前我們就已經(jīng)接觸過MYSQLI_result相關(guān)的內(nèi)容。它其實(shí)就是一個(gè)查詢的結(jié)果集。不過在PDO中,一般通過query()或者PDOStatement對象進(jìn)行查詢后就返回結(jié)果。但在MySQLi中,會(huì)把查詢到的結(jié)果也放入一個(gè)對象中,這就是MySQLI_result對象。

MySQLI_result 對象屬性

首先,我們要通過一段查詢來獲得一個(gè) MySQLI_result 對象。

$stmt = $mysqli->prepare("select * from zyblog_test_user where username = 'kkk'");

$stmt->execute(); // 執(zhí)行語句
$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() 方法執(zhí)行查詢語句之后,就可以通過 get_result() 方法獲得一個(gè) MySQLI_result 對象。

在這個(gè)對象中,我們可以看到有 current_field 當(dāng)前字段 、 field_count 字段數(shù)量 、 lengths 字段長度 、 num_rows 行數(shù) 、 type 這些屬性內(nèi)容。不少同學(xué)會(huì)發(fā)現(xiàn),current_field 和 lengths 好像并沒有什么實(shí)際的內(nèi)容,其實(shí)這兩個(gè)屬性是需要在特定操作下才會(huì)顯示內(nèi)容的,比如 lengths 是要在 fetch() 結(jié)果集之后才會(huì)有信息的。

$result->fetch_array();
var_dump($result);
// ……
// ……
// ["lengths"]=>
//   array(4) {
//     [0]=>
//     int(0)
//     [1]=>
//     int(3)
//     [2]=>
//     int(3)
//     [3]=>
//     int(2)
//   }
// ……
// ……

而 current_field 屬性的內(nèi)容我們將在下面遍歷查看字段信息的時(shí)候再展示它的內(nèi)容。

查詢結(jié)果集獲取

MySQLI_result 對象的可見屬性中,我們只能看到上面的那些信息。對于我們的業(yè)務(wù)開發(fā)來說其實(shí)用處不大,除了 num_rows 可以用來根據(jù)行數(shù)判斷查詢是否有結(jié)果之外,更重要的是我們要獲取到結(jié)果集中的數(shù)據(jù)信息,這時(shí)就需要使用其它的函數(shù)來進(jìn)行數(shù)據(jù)的獲取了。

獲取全部結(jié)果集

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() 方法就是用來獲取全部的數(shù)據(jù)集內(nèi)的數(shù)據(jù),并以數(shù)組的形式返回,它可以指定返回的格式,默認(rèn)情況下是 MYSQLI_NUM 這種數(shù)組下標(biāo)的形式,和 PDO 類似,我們直接指定為 MySQLI_ASSOC 就可以返回鍵名形式的數(shù)據(jù)內(nèi)容。

data_seek() 方法是移動(dòng)結(jié)果集的下標(biāo)。當(dāng)我們獲取或者使用后面要介紹的方法循環(huán)遍歷完成一次結(jié)果集之后,再次遍歷的話它的游標(biāo)已經(jīng)處于最后一位的,這樣是無法獲取數(shù)據(jù)的。在上面的代碼中,我們就是將游標(biāo)兩次返回到 0 下標(biāo)的位置,也就是最初始的位置,這樣我們就可以重復(fù)地操作這一個(gè)結(jié)果集了。

獲取普通結(jié)果集

如果要一行一行數(shù)據(jù)的獲取,我們就可以使用各種形式的結(jié)果集數(shù)據(jù)獲取方式。

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() 就是獲取下一行的結(jié)果數(shù)據(jù)并以數(shù)組的形式返回,同樣它也可以指定返回結(jié)果集的格式,和 fetch_all() 是類似的,只不過它是只獲取下一行而不是全部的數(shù)據(jù)集,而且它的參數(shù)默認(rèn)是返回的 MYSQLI_BOTH ,也就是數(shù)字下標(biāo)和鍵名下標(biāo)同時(shí)返回結(jié)果。

另外還有一個(gè) fetch_assoc() 方法,直接就是返回 MYSQLI_ASSOC 格式的數(shù)據(jù),這個(gè)方法不需要任何參數(shù),它可以看成是 fetch_array(MYSQLI_ASSOC) 這種使用方式的一個(gè)封裝。

var_dump($result->fetch_assoc());
// array(4) {
//     ["id"]=>
//     int(42)
//     ["username"]=>
//     string(3) "kkk"
//     ["password"]=>
//     string(3) "666"
//     ["salt"]=>
//     string(2) "k6"
//   }

而另外一個(gè)方法 fetch_row() ,則可以看成是和 fetch_array(MYSQLI_NUM) 相似的一個(gè)方法。它其實(shí)就是默認(rèn)指定為 MySQLI_NUM 的結(jié)構(gòu)返回方式。

var_dump($result->fetch_row());
// array(4) {
//     [0]=>
//     int(43)
//     [1]=>
//     string(3) "kkk"
//     [2]=>
//     string(3) "666"
//     [3]=>
//     string(2) "k6"
//   }

獲取對象結(jié)果集

獲取對象結(jié)果集其實(shí)和 PDO 中的相關(guān)功能也是類似的,它就是將結(jié)果直接放到一個(gè)類中,并實(shí)例化返回一個(gè)對象。

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 來返回的對象結(jié)構(gòu)。我們也可以指定一個(gè)類,并且可以為這個(gè)類的構(gòu)造函數(shù)傳遞參數(shù),這一點(diǎn)也和 PDO 中的相關(guān)功能一樣。

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"
//   }

查詢結(jié)果集字段信息獲取

接下來我們再看看 MySQLI_result 對象中的字段相關(guān)信息的獲取。我們可以直接獲取到當(dāng)前查詢的結(jié)果集中的所有字段信息。

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 屬性信息,可以看出,它指出的就是當(dāng)前位于哪個(gè)字段的下標(biāo)。

字段的信息非常詳細(xì),這些屬性的鍵名也很直觀,這里就不作詳細(xì)的說明了。

$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() 方法來移動(dòng)字段遍歷的游標(biāo)。在這里我們將游標(biāo)移動(dòng)到 1 ,就會(huì)從第二個(gè) 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() 則是根據(jù)參數(shù)來獲取指定下標(biāo)的字段信息。

以上是“PHP怎么使用MySQLi中的MySQLI_result對象操作”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI