Codeigniter で 2 つのデータベースを接続しようとしています。このリンクCodeigniter - 複数のデータベース接続に出くわし、要件に従ってデータベースをセットアップしました。問題は、デフォルトのデータベースだけがアクティブになっていることです。ここにコード
モデルがあります
function __construct()
{
parent::__construct();
$this->db_2 = $this->load->database('database2', TRUE);
$this->load->database();
}
function get_details()
{
$result1 = $this->db->query("select columnname1 from tablename")->result();
$result2 = $this->db_2->query("select columnname2 from tablename")->result();
}
columnname2
database2 テーブルにのみ存在し、database1 テーブルには存在しないため、エラーが発生します。Error: Unknown column 'columnname2' in 'field list'
データベース.php
$db['database2']['hostname'] = 'localhost';
$db['database2']['username'] = 'root';
$db['database2']['password'] = '';
$db['database2']['database'] = 'database2';
$db['database2']['dbdriver'] = 'mysql';
$db['database2']['dbprefix'] = '';
$db['database2']['pconnect'] = TRUE;
$db['database2']['db_debug'] = TRUE;
$db['database2']['cache_on'] = FALSE;
$db['database2']['cachedir'] = '';
$db['database2']['char_set'] = 'utf8';
$db['database2']['dbcollat'] = 'utf8_general_ci';
$db['database2']['swap_pre'] = '';
$db['database2']['autoinit'] = TRUE;
$db['database2']['stricton'] = FALSE;
$active_group = 'default';
$active_record = TRUE;
$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'root';
$db['default']['password'] = '';
$db['default']['database'] = 'database1';
$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;
更新:次を使用する場合
function __construct()
{
parent::__construct();
$this->load->database();
$this->db_2 = $this->load->database('database2', TRUE);
}
データベース 2 は CI によってアクティブと見なされ、すべてのクエリがデータベース 2 に接続さ$this->db->query();
れますが、クエリの指定に使用されます。