首页 > 数据库 > mysql教程 > 为什么我的 foreach 循环在使用'mysql_fetch_array”时显示双倍的数据?

为什么我的 foreach 循环在使用'mysql_fetch_array”时显示双倍的数据?

Patricia Arquette
发布: 2024-10-27 20:25:30
原创
920 人浏览过

Why does my foreach loop display doubled data when using `mysql_fetch_array`?

数组 (mysql_fetch_array) 中的结果加倍

由于 mysql_fetch_array 的操作方式,给定的代码遇到了 foreach 循环显示加倍数据的问题。默认情况下,它为结果数组中的每个元素分配数字索引和关联索引。这种效果可以在 print_r 输出中观察到,其中同时出现索引(0、1、2 等)及其相应的键(id、department_id、name 等)。

要解决此问题,您可以在 mysql_fetch_array 函数调用中指定所需的索引类型。通过传递 MYSQL_NUM 作为第二个参数,您可以检索仅包含数字键的数组。或者,MYSQL_ASSOC 将返回仅包含关联键的数组。

<code class="php">// Get numeric keys only
$query_result_array = mysql_fetch_array($query_result, MYSQL_NUM);

// Get associative keys only
$query_result_array = mysql_fetch_array($query_result, MYSQL_ASSOC);</code>
登录后复制

您还可以使用 mysql_fetch_row 和 mysql_fetch_assoc 函数,它们分别专门返回数字或关联数组:

<code class="php">// Get numeric keys only
$query_result_array = mysql_fetch_row($query_result);

// Get associative keys only
$query_result_array = mysql_fetch_assoc($query_result);</code>
登录后复制

通过利用这些选项,您可以避免 foreach 循环中的重复数据,并确保结果数组包含您需要的索引和值。

以上是为什么我的 foreach 循环在使用'mysql_fetch_array”时显示双倍的数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板