ci3怎样动态修改全局的数据库连接?
我的终极目标是想在controller,根据参数动态修改全局的数据库连接。比如现在2个数据配置都在database.php配置完毕,全局的数据库是$active_group = 'db1';我想在controller根据参数修改为调用db2(以后还会有db3、db4……)
我现在尝试了一些方法都不行:
controller获取参数后:
$this->load->database('db2', TRUE);
但是打印的$this->db信息还是原来的db1,我想让全局的$this->db变为db2的,应该如何实现呢?
$db2 = $this->load->database('db2', TRUE);
$sql="SELECT * FROM 。。。。。。";
$query=$db2->query($sql);
你在一个公用的Controller中如下配置
function __construct(){
parent::__construct();
$this->db2 = $this->load->database('db2', TRUE);
}
只要其他控制器继承这个控制器,就可以这么使用了:
$one =$this->db->where('id',1)->get('user')->row();
你在公用的控制器中如下配置:
function __construct(){
parent::__construct();
$this->db2 = $this->load->database('db2', TRUE);
}
只要其他控制器继承他,都可以实现你想要的$this->db2
页:
[1]