我的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数据库中工作正常,但在远程数据库中没有。我总是得到错误 致命错误:在非对象上调用成员函数result()
你能帮帮忙吗?我究竟做错了什么?我坚持这一点。答案 0 :(得分:0)
最后,我在联系我的网络托管服务提供商后找到了解决方案。该问题与远程数据库访问及其服务器有关。 IP地址例外和我添加的域名没有完成任务。我必须添加我的主机正在使用的内部域名,以便允许远程数据库访问。我花了2-3个小时与他们聊天,以找到解决方案。 无论如何现在已经解决了。我发布的是FYI。