在Codeigniter中为foreach()提供的参数无效

Clf*_*per 1 php mysql codeigniter

我收到错误消息:我的视图中的foreach()参数无效.我想显示我的mysql表中的所有条目,但我一直收到错误消息.我是Codeigniter的新手,无法弄清楚如何解决这个问题.代码如下:我的模型(display_branch.php)

<?php if(!defined ('BASEPATH')) exit ('No direct script access allowed');
class Display_Branch extends CI_Model
{
function __construct()
{
    parent::__construct();
}

public function getAll()
{
    $this->db->select('bcode, bname, btel, badd');
    $this->db->from('branches');

    $query = $this->db->get();

    if($query->num_rows() == 1)
    {
        $results = $query->result();
        return $results;
    }
    else
    {
        return FALSE;
    }
}
}?>
Run Code Online (Sandbox Code Playgroud)

我的控制器(link_controller.php)*只是片段.

public function insert()
{
    $this->load->model('display_branch');

    $data['results'] = $this->display_branch->getAll(); 

    $this->load->view('insert_branch');
    $this->load->view('navigation');
    $this->load->view('content_bc', $data);
    $this->load->view('footers');
}
Run Code Online (Sandbox Code Playgroud)

我的观点(content_bc.php)

<?php


        foreach($results as $row)
        {
            echo '<tr>';
            echo '<td>'.$row->bcode.'</td>';
            echo '<td>'.$row->bname.'</td>';
            echo '<td>'.$row->btel.'</td>';
            echo '<td>'.$row->badd.'</td>';
            echo '</tr>';
        }

?>
Run Code Online (Sandbox Code Playgroud)

请帮帮我怎么做.谢谢.

Sud*_*oti 11

您需要在开始迭代数据之前进行检查,例如:模型代码:

public function getAll() {
    $results = array();
    $this->db->select('bcode, bname, btel, badd');
    $this->db->from('branches');

    $query = $this->db->get();

    if($query->num_rows() > 0) {
        $results = $query->result();
    }
    return $results;
}
Run Code Online (Sandbox Code Playgroud)

查看代码:

if( !empty($results) ) {
    foreach($results as $row) {
        echo '<tr>';
        echo '<td>'.$row->bcode.'</td>';
        echo '<td>'.$row->bname.'</td>';
        echo '<td>'.$row->btel.'</td>';
        echo '<td>'.$row->badd.'</td>';
        echo '</tr>';
    }
}
Run Code Online (Sandbox Code Playgroud)