Codeigniter远程连接不返回查询

时间:2012-08-01 15:10:36

标签: mysql database codeigniter remote-connection

我的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()

你能帮帮忙吗?我究竟做错了什么?我坚持这一点。

1 个答案:

答案 0 :(得分:0)

最后,我在联系我的网络托管服务提供商后找到了解决方案。该问题与远程数据库访问及其服务器有关。 IP地址例外和我添加的域名没有完成任务。我必须添加我的主机正在使用的内部域名,以便允许远程数据库访问。我花了2-3个小时与他们聊天,以找到解决方案。 无论如何现在已经解决了。我发布的是FYI。