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