微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – mysqli_fetch_array()foreach循环重复

我正在对返回数组的数据库执行请求.我正在使用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循环,但它不是通过数据库条目,而是通过数组中的键/值对.

(如果我之前的陈述错了,请随时纠正我.)

把想法大声说出来

>当我写这个问题时,我开始怀疑,如果while和foreach似乎有点多余,因为两者似乎都会解析这些值,可能导致我的重复……?
>行号(在这种情况下为1)不是一个键吗?

解决方法:

认情况下,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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐