如何动态获取多个数据库连接?

时间:2015-02-05 16:08:37

标签: php codeigniter database-connection

我需要与Codeigniter建立3个数据库连接。我不知道有关这些数据库的主机,用户名或密码的任何信息。这意味着用户必须使用表单发送这些信息。

我所知道的是,可以在config / database.php中添加另一个数组,例如$ db [' another_db']但是如何动态设置主机名,用户名和密码的值?

我尝试使用自己的班级来做这件事,但我并没有真正工作:

<?php
class Connection_model extends CI_Model {
    public function define_database($member, $host, $user, $pw, $database) {
        $db[$member] = array(
                'dsn'   => '',
                'hostname' => $host,
                'username' => $user,
                'password' => $pw,
                'database' => $database,
                'dbdriver' => 'mysqli',
                'dbprefix' => '',
                'pconnect' => FALSE,
                'db_debug' => TRUE,
                'cache_on' => FALSE,
                'cachedir' => '',
                'char_set' => 'utf8',
                'dbcollat' => 'utf8_general_ci',
                'swap_pre' => '',
                'autoinit' => TRUE,
                'encrypt' => FALSE,
                'compress' => FALSE,
                'stricton' => FALSE,
                'failover' => array(),
                'save_queries' => TRUE
        );
    }

    public function get_person($member, $host, $user, $pw) {
        $otherdb = $this->load->database($this->define_database($member, $host, $user, $pw, $database), TRUE);

        $query = $otherdb->select('first_name, last_name')->get('person');
        var_dump($query);
    }
}

我在我的控制器上使用它:

    $this->load->model('connection_model');
    $this->connection_model->get_person('sender', 'localhost', 'root', '', 'test');

我收到消息:未定义的变量:数据库

我做错了什么?或者是否有其他方式来获得另一个连接?

1 个答案:

答案 0 :(得分:0)

查看 get_person 方法,需要4个参数:

public function get_person(**$member, $host, $user, $pw**) 

但在其中您调用方法 define_database 传递5个参数:

$this->define_database($member, $host, $user, $pw, **$database**)

CI给出错误,因为此范围内未定义第五个参数。