codeigniter 中的多个数据库连接错误

问题描述 投票:0回答:1

大家好,我在 CI 中连接多个数据库时遇到错误。当我连接到多个数据库时,有人可以指出我正确的方法吗?

这是我的database.php文件

$active_group = 'default';
$active_record = TRUE;
$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'root';
$db['default']['password'] = 'root';
$db['default']['database'] = 'cizacl';
$db['default']['dbdriver'] = 'mysql';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = '';
$db['default']['char_set'] = 'utf8';
$db['default']['dbcollat'] = 'utf8_general_ci';
$db['default']['swap_pre'] = '';
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;

$active_group = 'alternate';
$active_record = TRUE;
$db['alternate']['hostname'] = 'localhost';
$db['alternate']['username'] = 'root';
$db['alternate']['password'] = 'root';
$db['alternate']['database'] = 'vkwow_auth';
$db['alternate']['dbdriver'] = 'mysql';
$db['alternate']['dbprefix'] = '';
$db['alternate']['pconnect'] = TRUE;
$db['alternate']['db_debug'] = TRUE;
$db['alternate']['cache_on'] = FALSE;
$db['alternate']['cachedir'] = '';
$db['alternate']['char_set'] = 'utf8';
$db['alternate']['dbcollat'] = 'utf8_general_ci';
$db['alternate']['swap_pre'] = '';
$db['alternate']['autoinit'] = TRUE;
$db['alternate']['stricton'] = FALSE;  

然后这是检索我的模型中的所有记录函数

function getAll(){
$DB1 = $this->load->database('default',TRUE);
$DB2 = $this->load->database('alternate',TRUE);

//retrieve default DB
$query = $DB1->get('users');

if($query->num_rows() > 0){
foreach($query->result() as $row){
$data[] = $row;    
}
return $data; 
}

//retrieve alternate db
$query = $DB2->get('admins');
if($query->num_rows() > 0){
foreach($query->result() as $row){
$data[] = $row;    
}
return $data; 
}
}

这是我的输出视图代码

<p>
<?php foreach($records as $row) : ?>
<h1><?php echo $row->user_username;?></h1>
<?php endforeach; ?>
</p>

<p>
<?php foreach($records as $row) : ?>
<h1><?php echo $row->username;?></h1>
<?php endforeach; ?>
</p>  

当我运行这个程序时,我收到错误表“vkwow_auth.users”不存在

我很感激任何反馈/连接多个数据库的正确方法。

database codeigniter multi-database-connections
1个回答
1
投票

我不知道这是否真的是你的问题 - 但为什么你从模型中的 DB1 返回 $data ?因为它从未真正达到 DB2 请求。

您需要创建一个数组,然后在其中组合结果。

function getAll()
{
$DB1 = $this->load->database('default',TRUE);
$DB2 = $this->load->database('alternate',TRUE);

$data = new_array();
//retrieve default DB
$query = $DB1->get('users');

if($query->num_rows() > 0)
{
    foreach($query->result() as $row)
    {
         $data['db1'][] = $row;    
    }
}

//retrieve alternate db
$query = $DB2->get('admins');
if($query->num_rows() > 0)
{
    foreach($query->result() as $row)
    {
        $data['db2'][] = $row;    
    }

}

return $data;
}

然后只需更改视图输出以显示每个数组

编辑:“当我运行这个程序时,我收到错误表‘vkwow_auth.users’不存在” - 这实际上听起来不像数据库连接错误 - 看起来更像是查询错误?

© www.soinside.com 2019 - 2024. All rights reserved.