1

我正在尝试从数据库中选择数据,但出现此错误:

  A PHP Error was encountered        
    Severity: Warning
    Message: Invalid argument supplied for foreach()
    Filename: controllers/hello.php
    Line Number: 24

控制器:

<?php
    // system/application/controllers/hello.php

    class Hello extends CI_Controller {

       public function __construct()
       {
            parent::__construct();
       }

       function show_data() {

            $query = $this->load->model('user');
            foreach ($query->result() as $value) {
                echo $value -> username;
                echo $value -> password;
                echo $value -> first_name;
                echo $value -> last_name;
            }
       }
    }
?>

模型:

class User extends CI_Model {

    function __construct()
    {
        // Call the Model constructor
        parent::__construct();
    }

    function show()
    {
        $query = $this->db->get('user', 10);
        return $query->result();
    }
}

我正在看这个教程:https ://www.codeigniter.com/user_guide/database/results.html

错误是什么意思?

4

2 回答 2

4

你的控制器功能应该是这样的,

function show_data() {
    $this->load->model('user');
    $query = $this->user->show();
    foreach($query as $value) {
        echo $value->username;
        echo $value->password;
        echo $value->first_name;
        echo $value->last_name;
    }
}

在此处查看如何加载模型。

于 2013-02-02T21:50:26.823 回答
2

你调用 $query->result() 两次,一次在模型中,一次在循环中,你应该只做一次。那只是一个错误。

另一个更重要的是您启动模型(并将其分配给变量,这不是必需的,并且是一种不好的做法),并且您不会从模型中调用该函数。

所以首先你必须在控制器中启动你的模型(如果你打算更频繁地使用这个模型,你的函数或构造): $this->load->model('my_model');

然后你必须访问你想使用的函数: $this->my_model->my_model_function()

于 2013-02-02T21:46:34.777 回答