我正在对返回array
的数据库执行请求。我正在使用foreach
循环来查看值。
数据库(仅限1个条目)
id | field1 | field2 | field3 | field4 | field5
---|--------|--------|--------|--------|--------
1 | value1 | | value3 | value4 | value5
PHP源代码
$mysqli = new mysqli(DB_HOST, DB_USER, DB_PASS, DB_NAME);
$q = mysqli_query($mysqli, "SELECT * FROM my_table");
echo "<ul>";
while($q = mysqli_fetch_array($q))
{
foreach ($q as $key => $value)
{
if($value != NULL)
{
echo "<li>".$value . "</li>";
// Line below used to show column name and corresponding value
//echo "<li><strong>{$key}</strong> / <em>{$value}</em></li>";
}
}
}
echo "</ul>";
预期的HTML输出
<ul>
<li>value1</li>
<li>value3</li>
<li>value4</li>
<li>value5</li>
</ul>
当前输出
<ul>
<li>1</li>
<li>1</li>
<li>value1</li>
<li>value1</li>
<li>value3</li>
<li>value3</li>
<li>value4</li>
<li>value4</li>
<li>value5</li>
<li>value5</li>
</ul>
当前问题
正如你所看到的,我目前所有东西都是双倍的,并且出于一些奇怪的原因,我得到了行ID,或者我认为当我向数据库添加新行时我没有得到第二行
替代代码
使用注释行,我得到了这个输出:
<ul>
<li>0 / 1</li>
<li>id / 1</li>
<li>1 / value1</li>
<li>field1 / value1</li>
<li>3 / value3</li>
<li>field3 / value3</li>
<li>4 / value4</li>
<li>field4 / value4</li>
<li>5 / value5</li>
<li>field5 / value5</li>
</ul>
根据我的理解
while
循环允许我遍历数据库中的每一行。foreach
循环类似于while
循环,但不是通过数据库条目,而是来自array
的键/值对。(如果我之前的陈述错了,请随时纠正我。)
大声思考
while
和foreach
似乎有点多余,因为两者似乎都会解析这些值,可能导致我的重复......? 1
)不是一个键吗?答案 0 :(得分:8)
默认情况下,mysqli_fetch_array()
同时返回一个关联数组($key => $value
)和一个数字数组(0 => value
),这就是你得到重复项的原因 - 有些条目有列名作为键,其他名称具有数字索引。
如果你想要一个关联数组,你可以使用:
mysqli_fetch_array($q, MYSQLI_ASSOC);
//or
mysqli_fetch_assoc($q);
或者对于数字数组:
mysqli_fetch_array($q, MYSQLI_NUM);
//or
mysqli_fetch_row($q);
了解更多信息:http://www.php.net/manual/en/mysqli-result.fetch-array.php