dongzi1209 2018-12-04 16:27
浏览 427

PHP SQL $ stmt-> fetch()将数组推送到另一个数组中

I have some problems with $stmt->fetch()

I have a variable called $row which consists of $row['id'] and $row['name']. In the $stmt->fetch() loop I want to append the row to a $result array. But if print the $result array it only consists out of the last row.

Here is my code:

function queryResult($sql, $params, $columNames) {

    $result = [];
    $row = [];
    $bindVars = [];

    for ($i = 0; $i < sizeof($columNames); $i++) {
        $bindVars[] = &$row[$columNames[$i]];
    }

    $stmt = $this->query($sql, $params);
    call_user_func_array([$stmt, 'bind_result'], $bindVars);

    while ($stmt->fetch()) {
        print_r($row);
        echo '<br>';
        array_push($result, $row);
        print_r($result);
        echo '<br><br>';
    }

    return $result;

}

And this is the result:

Array ( [id] => 2 [name] => Test2 ) 
Array ( [0] => Array ( [id] => 2 [name] => Test2 ) ) 

Array ( [id] => 3 [name] => Test3 ) 
Array ( [0] => Array ( [id] => 3 [name] => Test3 ) [1] => Array ( [id] => 3 [name] => Test3 ) ) 
  • 写回答

2条回答 默认 最新

  • doue2666 2018-12-04 17:09
    关注

    In line 14 I think while($row=mysqli_fetch_array($stmt)) should be used.

    评论

报告相同问题?

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集