13 PHP数据的获取

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 路老师在知乎上分享了PHP语言的知识,帮助大家入门和深入理解PHP。本文介绍了从结果集中获取一行数据作为对象(`mysqli_fetch_object()`)、获取一行作为枚举数组(`mysqli_fetch_row()`)、获取查询结果集中的记录数(`mysqli_num_rows()`)、释放内存(`mysqli_free_result()`)以及关闭数据库连接(`mysqli_close()`)的方法,并提供了具体示例代码。
有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享
路老师给大家分享PHP语言的知识了,旨在想让大家入门PHP,并深入了解PHP语言。

image.gif 编辑


1 从结果集中获取一行作为对象

表中数据行如下:

image.gif 编辑

利用mysqli_fetch_array()函数获取结果集中的数据,获取的是所有的数据行,上篇文章已经介绍了。本篇介绍一个新的函数:mysqli_fetch_object()可以轻松的获取一行数据作为对象,语法如下:

//返回一个对象而不是一个数组,该函数通过字段名来访问数组
mixed mysqli_fetch_object(resource result)
//访问结果集行中元素的语法如下:
$row->col_name  //col_name 为字段名, $row代表结果集

image.gif

接下来看下如何在案例中使用(展示核心代码):

<tbody>
                            <?php while($obj = mysqli_fetch_object($result)){ 
                               if(is_object($obj)){ //判断对象是否存在    
                            ?>
                                <tr>
                                    <td class="table-text">
                                        <?php echo $obj->id ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $obj->name ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $obj->category ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $obj->price ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $obj->publish_time ?>
                                    </td>
                                    <td>
                                        <a href="editBook.php?id=<?php echo $obj->id ?>">
                                            <button class="btn btn-info edit">编辑</button>
                                        </a>
                                        <a href="deleteBook.php?id=<?php echo $obj->id ?>">
                                            <button class="btn btn-danger delete">删除</button>
                                        </a>
                                        
                                    </td>
                                </tr>
                            <?php }
                             } ?>
                        </tbody>

image.gif

image.gif 编辑

2 从结果集中获取一行作为枚举数组

mysqli_fetch_row()函数可以从结果集中取得一行作为枚举数组,即数组的键用数字索引来表示。

mixed mysqli_fetch_row(resource $result)

image.gif

该函数返回根据所取得的行生成的数组,如果没有更多行则返回null。返回数组的偏移量从0开始,即以$row[0]的形式访问第一个元素(只有一个元素时也是如此)。

接下来看下如何在案例中使用(展示核心代码):

<tbody>
                            <?php while($rows = mysqli_fetch_row($result)){ 
                              
                            ?>
                                <tr>
                                    <td class="table-text">
                                        <?php echo $rows[0] ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $rows[1] ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $rows[2] ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $rows[3] ?>
                                    </td>
                                    <td class="table-text">
                                        <?php echo $rows[4] ?>
                                    </td>
                                    <td>
                                        <a href="editBook.php?id=<?php echo $rows[0] ?>">
                                            <button class="btn btn-info edit">编辑</button>
                                        </a>
                                        <a href="deleteBook.php?id=<?php echo $rows[0] ?>">
                                            <button class="btn btn-danger delete">删除</button>
                                        </a>
                                        
                                    </td>
                                </tr>
                            <?php 
                             } ?>
                        </tbody>

image.gif

image.gif 编辑

 3 获取查询结果集中的记录数

//语法如下
int mysqli_num_rows(resource $result)

image.gif

注意:该函数只对select语句有效,要取得被insert、update或者delete语句所影响到的行数,则要使用mysqli_affected_rows()函数。

在index.php里设置mysqli_num_rows()函数统计行数,在lists.html里显示行数:

<?php
 $dbName = 'db_test';
 $link = mysqli_connect('localhost','root','passwd');
 if(mysqli_select_db($link,$dbName)) {
    
    $result = mysqli_query($link,"select * from books");
    $numRows = mysqli_num_rows($result);
    
    include_once('lists.html');
  
 } else{
  echo $dbName."未连接!";
 }
?>

image.gif

在</table>下面添加一行:

<p class="text-primary text-center">共计 <?php echo $numRows ?></p>

image.gif

image.gif 编辑

效果如下:

image.gif 编辑  4 释放内存

数据库操作完后,需要关闭结果集,以释放系统资源,采用mysqli_free_result()函数释放内存。语法如下:

void mysqli_free_result(resource $result)

image.gif

注意:mysqli_free_result()函数将释放所有与结果符$result相关联的内存。该函数仅需要在考虑到返回很大的结果集会占用较多内存时调用。在执行结束后所有关联的内存都会被自动释放。

5 关闭连接(数据库连接)

完成数据库的操作后,要及时断开与数据库的连接并释放内存,否则会浪费大量的内存空间,在访问量较大的Web项目中,很可能导致服务器崩溃。在MySQL数据库中,使用mysqli_close()函数断开与MySQL服务器的连接,语法如下:

bool mysqli_close(mysqli $link)

image.gif

<?php
 $dbName = 'db_test';
 $link = mysqli_connect('localhost','root','passwd');
 if(mysqli_select_db($link,$dbName)) {
    
    $result = mysqli_query($link,"select * from books");
    $numRows = mysqli_num_rows($result);
    
    include_once('lists.html');
    //释放内存
    mysqli_free_result($result);
    //关闭Mysql服务器连接
    mysqli_close($link);
  
 } else{
  echo $dbName."未连接!";
 }
?>

image.gif

下篇 PHP 结合数据库实现图书信息管理小案例

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
8月前
|
JSON 数据处理 PHP
PHP数组处理技巧:高效操作数据集合
PHP数组处理技巧:高效操作数据集合
|
8月前
|
JSON 安全 大数据
PHP中的数组处理艺术:灵活高效的数据操作
PHP中的数组处理艺术:灵活高效的数据操作
|
8月前
|
JSON 定位技术 PHP
PHP技巧:解析JSON及提取数据
这就是在PHP世界里探索JSON数据的艺术。这场狩猎不仅仅是为了获得数据,而是一种透彻理解数据结构的行动,让数据在你的编码海洋中畅游。通过这次冒险,你已经掌握了打开数据宝箱的钥匙。紧握它,让你在编程世界中随心所欲地航行。
264 67
|
11月前
|
数据库连接 PHP 数据库
【YashanDB知识库】PHP使用ODBC驱动无法获取长度为256char以上的数据
【YashanDB知识库】PHP使用ODBC驱动无法获取长度为256char以上的数据
|
11月前
|
Oracle 关系型数据库 MySQL
【YashanDB知识库】php查询超过256长度字符串,数据被截断的问题
本文分析了YashanDB中PHP通过ODBC查询数据时出现的数据截断问题,表现为超过256字节的数据被截断,以及isql工具无法显示超过300字节长度的数据。问题根源在于YashanDB的ODBC驱动仅支持单次查询,且PHP扩展库默认缓冲区限制。解决方案包括改用PHP ODBC扩展库而非PDO_ODBC,以及调整isql代码逻辑以支持循环取数或一次性读取完整数据。文章还提供了具体代码示例和规避方法,适用于23.2.4.14及更早版本。
【YashanDB知识库】php查询超过256长度字符串,数据被截断的问题
|
数据采集 JSON JavaScript
如何通过PHP爬虫模拟表单提交,抓取隐藏数据
本文介绍了如何使用PHP模拟表单提交并结合代理IP技术抓取京东商品的实时名称和价格,特别是在电商大促期间的数据采集需求。通过cURL发送POST请求,设置User-Agent和Cookie,使用代理IP绕过限制,解析返回数据,展示了完整代码示例。
354 3
如何通过PHP爬虫模拟表单提交,抓取隐藏数据
|
12月前
|
Oracle 关系型数据库 MySQL
【YashanDB 知识库】php 查询超过 256 长度字符串,数据被截断的问题
php 查询超过 256 字节数据,显示被截断:yashandb 的 odbc 驱动接口 SQLGetData 现在只支持单次查询,不支持多次取数据的操作。 isql 显示不出来,isql 工具最大只查询 300 长度的数据,超过了该长度未正常显示。
|
缓存 NoSQL PHP
Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
290 5
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
339 3
|
存储 SQL 数据处理
PHP中如何高效地处理大规模数据的排序?
在PHP中处理大规模数据排序时,选择合适的方法至关重要。对于内存内可以处理的数据,可以直接使用PHP内置排序函数;对于超出内存限制的数据,可以考虑分块处理、外部排序或利用数据库的排序功能。根据具体应用场景和数据规模,选择最佳的排序策略,确保排序操作高效且稳定。
181 2