我与我的 mysql 数据库有本地和远程连接。本地连接工作得很好。但是远程连接,当它建立连接时,它不会返回任何东西。我通常会得到以下信息:
致命错误:在非对象上调用成员函数 result()
我使用以下配置进行远程连接:
$db['mydb']['hostname'] = "ip_address_of_database";
$db['mydb']['username'] = "username";
$db['mydb']['password'] = "password";
$db['mydb']['database'] = "database";
$db['mydb']['dbdriver'] = "mysql";
$db['mydb']['dbprefix'] = "";
$db['mydb']['pconnect'] = FALSE;
$db['mydb']['db_debug'] = FALSE;
$db['mydb']['cache_on'] = FALSE;
$db['mydb']['cachedir'] = "";
$db['mydb']['char_set'] = "utf8";
$db['mydb']['dbcollat'] = "utf8_general_ci";
在访问数据库的函数中,我检查是否与远程服务器建立连接,然后尝试检索数据。
$mydb = $this->load->database('mydb', TRUE);
if (!isset($mydb->conn_id) && !is_resource($mydb->conn_id)) {
$error = 'database is not connected';
return $error;
}else{
$query = $mydb->query("SELECT * FROM database LIMIT 1;");
return $query->result();
}
这在 localhost 数据库中可以正常工作,但在远程数据库中则不行。我总是收到错误 Fatal error: Call to a member function result() on a non-object
你能帮忙吗?我究竟做错了什么?我坚持这一点。