PHP如何使用MySQLi中的MySQLI_result对象操作

在之前我们就已经接触过mysqli_result相关的内容。它其实就是一个查询的结果集。不过在pdo中,一般通过query()或者pdostatement对象进行查询后就返回结果。但在mysqli中,会把查询到的结果也放入一个对象中,这就是mysqli_result对象。

PHP如何使用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() 结果集之后才会有信息的。

立即学习“PHP免费学习笔记(深入)”;

$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对象操作的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2115781.html

(0)
上一篇 2025年2月24日 17:13:32
下一篇 2025年2月24日 17:13:51

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 做为一名优秀的php工程师,这些 Linux 指令你都掌握了吗?

    前言 本文收录了 linux 常用指令,这里面有个小技巧,基本上所有指令后面跟上 –h 可以显示其使用方法。故不必死记硬背,知其意乃通其形。(推荐:Linux视频教程) 分类如下:  ● 文件 & 目录操作(16 个) …

    2025年3月13日
    400
  • 使用PHP和Vue.js构建快速响应式 Web 应用程序

    在当今的时代,web 应用程序需要快速响应和高效的交互特性来满足用户的需求。为此,php 和 vue.js 成为了两个广泛使用的工具,用于构建快速响应式的 web 应用程序。 PHP 是一种流行的服务器端脚本语言,它可以协助 Web 开发人…

    编程技术 2025年3月13日
    200
  • 如何在PHP中实现爬虫功能

    在互联网时代,信息获取已经成为人们日常生活中的重要部分。然而,与此同时,人们也需要处理大量的信息以提取重要的数据。这就促使出现了“爬虫”这个概念。爬虫,又称网络蜘蛛,是一种按照特定规则自动获取网页信息的程序。在php中,实现爬虫功能可以采用…

    编程技术 2025年3月13日
    200
  • PHP中如何进行跨领域分析和综合分析?

    近年来,跨领域分析和综合分析在数据分析领域越来越受到重视。在php编程语言中,我们也可以进行跨领域分析和综合分析,以发现数据中的更多信息和价值。本文将介绍php中的跨领域分析和综合分析方法。 一、跨领域分析 跨领域分析是指使用不同领域的知识…

    编程技术 2025年3月13日
    200
  • PHP中的机器学习

    在当今时代,机器学习已经不再是一项神秘的技术。越来越多的人意识到了机器学习的重要性,并且开始学习和应用。但是,大多数人在想到机器学习时,首先想到的是python,而很少有人知道php也可以进行机器学习。 PHP是一种通用编程语言,通常用于W…

    编程技术 2025年3月13日
    200
  • 如何用PHP打造完美的表单验证

    在网页开发中,表单验证是非常重要的一环,它可以保证用户的输入数据符合指定的格式和规则,有效地防止了一些不必要的错误和恶意行为。而php作为一种强大且流行的编程语言,可以通过编写代码来实现表单验证的功能。但是,如何用php打造完美的表单验证?…

    编程技术 2025年3月13日
    200
  • PHP如何实现用户画像分析,提升精准营销

    随着互联网和移动互联网的快速普及和发展,大数据时代已经到来。各行各业都在积极探索如何利用大数据,进行精准营销。其中,用户画像分析是一种非常有效的营销手段。而php作为开发网站和数据处理的语言,也可以用来实现用户画像分析。本文将介绍如何利用p…

    编程技术 2025年3月13日
    200
  • PHP实现实时社交媒体分析技术研究

    社交媒体在当今社会中的地位越来越重要,人们通过社交媒体获得信息、发布信息和进行互动。社交媒体上的大数据信息一直是许多机构和企业关注的焦点,而实时社交媒体分析技术正是应运而生的。本文将探讨如何利用php来实现实时社交媒体分析技术。 一、实时社…

    编程技术 2025年3月13日
    200
  • 如何使用PHP和Vue.js构建单页面应用

    近年来,随着web应用程序的日渐复杂,单页面应用(spa)的概念渐渐成为了前端开发的新潮流。spa是一种web应用程序,它使用异步javascript和xml(ajax)来实现无需重新加载整个页面的用户界面更新。在spa中,所有页面内容都在…

    编程技术 2025年3月13日
    200
  • php接口安全:php接口加密的四个方案

    本篇文章给大家带来的内容是关于php接口安全:php接口加密的四个方案,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。        作为一名互联网coder,无论你是前端或者后端你都要对http请求要有一定的了解,知道ht…

    编程技术 2025年3月13日
    200

发表回复

登录后才能评论