-1

我有一个从名为 db 的基类扩展的应用程序类。当我尝试创建实例时,出现错误

在非对象上调用成员函数 query()。

我的应用程序类是:

Class Application extends DB
{

public $sql;

 /*
  * Public Methods
 */
/*
 * Constructor
 */
function Application() {
    global $sql;

    $sql = db::getInstance();
}

function selectSqli($access_table){
    $result = $sql->query("select * from $access_table");
    return $result;
}

}

我的数据库类是:

class db extends mysqli{
protected static $instance;
protected static $options = array();

private function __construct() {
    $db = self::$options;

    // turn of error reporting
    mysqli_report(MYSQLI_REPORT_OFF);

    // connect to database
    @parent::__construct(isset($db['host'])   ? $db['host']   : 'localhost',
                         isset($db['user'])   ? $db['user']   : 'root',
                         isset($db['pass'])   ? $db['pass']   : '',
                         isset($db['dbname']) ? $db['dbname'] : 'angler_blog_post');

    // check if a connection established
    if( mysqli_connect_errno() ) {
        throw new exception(mysqli_connect_error(), mysqli_connect_errno()); 
    }
}

public static function getInstance() {
    if( !self::$instance ) {
        self::$instance = new self(); 
    }
    return self::$instance;
}

public function query($query) {
    if( !$this->real_query($query) ) {
        throw new exception( $this->error, $this->errno );
    }

    $result = new mysqli_result($this);
    return $result;
}
}

我尝试了 global,plublic,但我无法访问函数 query()。如何解决这个错误。

4

2 回答 2

1

你应该更好地注入你的数据库对象而不是使用global $sql;

但在你的情况下,$sql是一个局部变量,而不是属性。正如您在构造函数中声明的那样$this->sql$sql当前对象的属性现在包含 DB 对象的实例。

所以,它应该是:

function selectSqli($access_table){
    $result = $this->sql->query("select * from $access_table");
    return $result;
}

还有,你可能不知道一些关于 PHP 5 的消息,因为使用类似于类名的方法名来实现构造函数,在 PHP 5 中你应该使用一个特殊的方法__construct() {},即构造函数。

在 OOP 中查看 PHP 5 的新功能:http ://www.php.net/manual/en/language.oop5.php

于 2014-05-04T11:21:32.693 回答
0
function selectSqli($access_table){
    global $sql;
    $result = $sql->query("select * from $access_table");
    return $result;
}

或者,如果您使用 OOP:

Class Application extends DB
{

public $sql;

 /*
  * Public Methods
 */
/*
 * Constructor
 */
function Application() {
    $this->sql = db::getInstance();
}

function selectSqli($access_table){
    $result = $this->sql->query("select * from $access_table");
    return $result;
}
}
于 2014-05-04T11:10:21.423 回答