0

调用我的数据库类并运行查询函数时出现此错误。

这是我的课:

class dbConnect {

public $mysqli = null;

public function __construct() {
    $this->mysqli = new mysqli( "localhost", "root", "pass", "database" );
    if ($this->mysqli->connect_errno) 
    {
        echo "Error MySQLi: ("&nbsp. $this->mysqli->connect_errno 
        . ") " . $this->mysqli->connect_error;
        exit();
    }
    $this->mysqli->set_charset("utf8"); 
}

public function __destruct() {
    $this->closeDB();
}

public function runQuery($qry) {
    $result = $this->mysqli->query($qry);
    return $result;
}

这是我的页面:

$db = new dbConnect();
$insert = "INSERT INTO `users` (`username`,`password`,`email`,`ip`,`date`) VALUES ('$username','$pw','$email','$ip','$time')";

$db->runQuery( $insert ) or die("Error MySQLi: ("&nbsp. $db->mysqli->connect_errno . ") " . $db->mysqli->connect_error);

编辑:

我现在收到错误 Dbr`0

4

4 回答 4

1

改变这个:

$db->runQuery( $insert ) or die("Error MySQLi: ("&nbsp. $this->mysqli->connect_errno . ") " . $this->mysqli->connect_error);

对此:

$db->runQuery( $insert ) or die("Error MySQLi: ("&nbsp. $db->mysqli->connect_errno . ") " . $db->mysqli->connect_error);

但是,我建议您创建一个方法来获取错误,而不是$db->mysqli直接访问您的数据库对象 ()。

于 2013-09-28T22:28:47.180 回答
1

在骰子的最后一行中,您不在对象中。

于 2013-09-28T22:28:03.370 回答
0

在您的or die声明中,您忘记了 a $this,将其替换为$db

于 2013-09-28T22:29:24.013 回答
0

我没有在你的类中看到任何你在 __destruct() 函数中调用它的 closeDB 函数:也在你的查询中$this->closeDB(); 替换$this->mysqli->connect_errno为!$db->mysqli->connect_errno

于 2013-09-28T22:32:45.790 回答