我在调用数据库类并运行查询函数时收到此错误。
这是我的班级:
class dbConnect {
public $mysqli = null;
public function __construct() {
$this->mysqli = new mysqli( "localhost", "root", "pass", "database" );
if ($this->mysqli->connect_errno)
{
echo "Error MySQLi: (" . $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: (" . $db->mysqli->connect_errno . ") " . $db->mysqli->connect_error);
编辑:
我现在收到错误 Dbr'0
在骰子的最后一行中,您不在对象中。
更改以下内容:
$db->runQuery( $insert ) or die("Error MySQLi: (" . $this->mysqli->connect_errno . ") " . $this->mysqli->connect_error);
对此:
$db->runQuery( $insert ) or die("Error MySQLi: (" . $db->mysqli->connect_errno . ") " . $db->mysqli->connect_error);
但是,我建议您创建一种方法来获取错误,而不是直接访问数据库对象($db->mysqli
)。
在or die
语句中,您忘记了$this
,将其替换为$db
我在您的类中没有看到您在 __destruct() 函数中调用它的任何 closeDB 函数,如下所示:$this->closeDB();
还要在查询中将$this->mysqli->connect_errno
替换为$db->mysqli->connect_errno
!