首页  >  文章  >  数据库  >  为什么我的 foreach 循环在使用“mysql_fetch_array”时显示双倍的数据?

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

Patricia Arquette
Patricia Arquette原创
2024-10-27 20:25:30828浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn