複数データベースの追加と切替

CakePHPで複数のデータベースに切替を行うということがあると思います。(個人的にはあまりない)
今回、CakePHPからWordpressのデータベースへの接続を行う機会があったので設定を試してみました。(そもそも同じデータベースにしておくという方法もあると思いますが。)
データベースの追加
app/core/database.phpに設定を追加します。
class DATABASE_CONFIG { var $default = array( .... ); // 追加するデータベースの設定 var $testdatabase= array( 'driver' => 'mysql', // データベースドライバー名 'persistent' => false, // persistent connectを行うか否か。 'host' => 'dbhost', // データベースホスト名 'login' => 'user', // 接続ユーザ名 'password' => 'password', // 接続パスワード 'database' => 'testdatabase', // データベース名 'prefix' => '', // 'encoding' => 'utf8', // ); }
データベースの切替
データベースの切替は各モデルごとに設定できます。
$useDbConfigを指定することで違うデータベースへ接続することができます。指定無しの場合は$defaultのデータベースへ接続されます。
<?php class Testmodel extends AppModel { var $useDbConfig = 'testdatabase'; } ?>
関連記事
-
-
WYSIWYGエディタを実装
WYSIWYGエディタをCakePHPにいくつか試してみました。 CKEditor 実装 // head // View(~.ctp) 解凍してwebroot/jsフ
-
-
ログローテーション
CakePHP1.3では標準ではログはタイプごとに出力されるだけで、定期的なローテーションを行ってくれません。放っておくとひたすら1つのファイルにアペンドされていきます。app/tmp/logs以下に
-
-
Cookieログイン
今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook
-
-
CakePHP 1.3 インストール
使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア
-
-
recursive設定によるfind()性能改善
CakePHPでは、モデルにアソシエーションを設定している場合、recursive(=>joinする階層)はデフォルトで0に設定されています。「recursiveゼロ」の意味するところとは、「1跨ぎま
-
-
メール送信(qdmail)
CakePHP(+qdmail)でメール送信する処理を実装しました。 準備 2つのライブラリ(.php)をダウンロードし、以下のように配置して下さい。 app/controllers/compo
-
-
シンプルに設置できる数字Captcha「MathCaptcha」
スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。 この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は
-
-
validateErrors と validationErrors
CakePHP試験中に気付いたことがあって、メモです。 $this->validateErrors自身バリデーション処理している 今まで、save時にバリデーションエラーメッセージををログに出力し
-
-
Htmlヘルパー
ソース:\cake\libs\view\helpers\html.php charset / 文書の文字コードを設定する <?php echo $this->Html-
-
-
コントローラ内でバリデーション処理を呼び出す
通常、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。 バリデーシ
- PREV
- CakePHP 1.3 インストール
- NEXT
- 複数ファイルアップロード