Codeigniter3で異なるデータベースを使用する
2024/02/25
Codeigniterで2つのコンテンツがあって、それぞれ別のデータベースを使用したかった。調べてみると以下方法で対応できた。
事前設定
「codeigniter/config/database.php」に新たにデータベース情報を追記する。
$db['default'] = array(
'dsn' => '',
'hostname' => 'localhost',
'username' => 'MySQLのユーザー名',
'password' => 'MySQLのパスワード',
'database' => '使用するデータベース名',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
//↓↓を追記する
$db['db2'] = array( //キーをdefaultとは違うものにする
'dsn' => '',
'hostname' => 'localhost',
'username' => 'MySQLのユーザー名',
'password' => 'MySQLのパスワード',
'database' => '使用するデータベース名',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
使用方法
モデル側でデータベースを読み込む際に、引数を入れる。
function __construct()
{
parent::__construct();
$this->load->database('db2');
}
引数は先ほど設定した配列のキーを入れる。
その他
特に問題なくいけたけど、1つのコンテンツで複数のデータベースを使う時とかはもしかすると面倒なのかも。
関連記事
-
-
CodeIgniter3でCronを実行する方法
CodeIgniter3系で特定の処理をCronで自動実行したかった。以下に設定 ...
-
-
CodeIgniter4でコントローラ実行の前後に指定したイベントを実行する方法
CodeIgniter4で特定の条件の場合は指定したページにリダイレクトさせたい ...
-
-
CodeIgniter4で簡易版ログインシステムの実装方法(管理画面向け)
CodeIgniter4で管理画面向けの簡易版ログインシステムを作成したい。通常 ...
-
-
CodeIgniter4でのメール送信方法(テキスト・HTMLメール)
CodeIgniter4.4.4でテキストメール及びHTMLメールを送信したい。 ...
-
-
Codeigniter3で外部ファイル(CSS / JS)の読み込みと共通パーツ化する方法
CodeigniterでCSSやJSファイル等の外部ファイル読み込みたかった。ま ...