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

php – multidimensional数组使用foreach返回错误的结果

我有一个mysql数据库交互的PHP类,然后获取一个数组作为结果.

$res = $db->getResult(); // $res is an array

我用它与print_r:

print_r($res);

输出

Array
(
    [0] => Array
        (
            [id] => 1
            [firstname] => Mohamed
            [lastname] => Kadri
        )

    [1] => Array
        (
            [id] => 2
            [firstname] => Slim
            [lastname] => Nejmaoui
        )

    [2] => Array
        (
            [id] => 3
            [firstname] => Sameh
            [lastname] => Chraiti
        )

并与foreach:

foreach ($res as $row) {
    echo $row['id'] . ' ' . $row['firstname'] . ' ' . $row['lastname'] . '<br />';
}

输出这个:

1 Mohamed Kadri
2 Slim Nejmaoui
3 Sameh Chraiti

但是当只有一行时,它会显示

1 1 1
M M M    
K K K

(1是id,M是firstname中的第一个字母,K是lastname中的第一个字母).

因此,当有多行时,类会生成一个多维数组,而foreach将对其进行处理,当只有一行时,它会生成一个简单的数组,该数组将被这个精确的foreach视为多维数组.

那么我应该制定条件来处理两种类型的foreach中的一种吗?

谢谢.

解决方法:

显然你的db对象只返回一个结果,只有一个结果:

Array
(
    [id] => 2
    [firstname] => Slim
    [lastname] => Nejmaoui
)

你可以测试第一个输入,如果这不是一个数组,不要循环thrue foreach其他做foreach

if( is_array(current($res)) ){
  // do the foreach...
}else{
  echo $res['id'] . ' ' . $res['firstname'] . ' ' . $res['lastname'] . '<br />';
}

我认为你应该改变你的db类,即使在单行结果上也总是返回一个嵌套数组,以保持你的结果一致.

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

相关推荐