2

这是我第一次尝试在 CodeIgniter 中编写代码。问题是它无法从数据库中检索数据。它抛出的错误是:

A PHP Error was encountered

Severity: Notice

Message: Undefined property: Site::$db

Filename: core/Model.php

Line Number: 51

我可以理解在core/model.php.

这是另一个错误:

 Fatal error: Call to a member function query() on a non-object in C:\wamp\www\CI_one\application\models\site_model.php on line 9

控制器

<?php
    class Site extends CI_Controller {
        function datta(){
            $this->load->model('site_model');
            $get = $this->site_model->getValues();
            $data['get'] = $get;
            $this->load->view('data3',$data);
        }
    }

模型

<?php
    class site_model extends CI_Model{

        function index(){
            echo "default index";
        }

        function getValues(){
            $query = $this->db->query("select * from nav_menu");

            if ($query->num_rows() > 0)
            {
               foreach ($query->result() as $row)
               {
                  echo $row->c1;
                  echo $row->m2;
                  echo $row->d3;
               }
            }
            return array(
                "name" => "nameless",
                "form" => "formless",
                "age"  => "ageless");
        }
    }

我已经在app/config/database.php.

我该如何进行这项工作?


我自己解决了。我擦掉并重新编码如下以获得结果......

控制器

<?php
    class Site extends CI_Controller {
        function datta(){

            $this->load->database();
            $this->load->model('site_model');
            $get = $this->site_model->getValues();
            $data['get'] = $get;
            $this->load->view('data3',$data);
        }
    }

模型为

<?php
    class site_model extends CI_Model{

        function index(){
            echo "default index";
        }

        function getValues(){
            $query = $this->db->query("select * from nav_menu");

            if ($query->num_rows() > 0)
            {
               foreach ($query->result() as $row)
               {
                  echo $row->c1;
                  echo $row->m2;
                  echo $row->d3;
               }
            }
            return array(
                "name" => "nameless",
                "form" => "formless",
                "age"  => "ageless");
        }
    }
4

3 回答 3

2

在 Codeigniter 中,您必须手动加载数据库库,如下所示:

$this->load->database(); 

或者您必须按照 Sandip 的说明自动加载库。

在您的应用程序中,您可能需要自动加载多个库和帮助程序,因此最好不要手动加载它们,而是自动加载。请在此处阅读有关自动加载的信息。

http://ellislab.com/codeigniter/user-guide/general/autoloader.html

另请阅读文档的其余部分,您将从那里了解有关 CI 的所有信息。它很简单,简洁并且有例子。

希望这会有所帮助。

于 2013-03-20T05:23:25.743 回答
0

请在 CodeIgniter 控制器中编写一个构造函数:

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

除此之外:

您必须先加载数据库库。在

自动加载.php:

  $autoload[‘libraries’] = array(‘database’);

或者在控制器构造函数中为:

  $this->load->database();

我希望它会有所帮助!

于 2013-03-20T05:17:29.190 回答
0

试试这个 :

控制器 :

<?php
class Site extends CI_Controller {
    function datta(){
        $this->load->database();
        $this->load->model('site_model');
        $get=$this->site_model->getValues();
        $data['get']=$get;
        $this->load->view('data3',$data);
    }
}
于 2013-03-20T05:23:44.730 回答