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

CakePHPで複数のデータベースに切替を行うということがあると思います。(個人的にはあまりない) 今回、CakePHPからWordpressのデータベースへの接続を行う機会があったので設定を試してみました。そもそも同じデータベースにしておくという方法もあると思いますが。

データベースの追加

app/core/database.phpに設定を追加します。

class DATABASE_CONFIG {
    var $default = array(
        ....
    );
    // 追加するデータベースの設定
    var $wordpress= array(
        'driver' => 'Database/Mysql', // データベースドライバー名
        'persistent' => false,        // persistent connectを行うか否か。
        'host' => 'dbhost',           // 接続データベースホスト名
        'login' => 'user',            // 接続ユーザ名
        'password' => 'password',     // 接続パスワード
        'database' => 'wordpress',    // データベース名
        'prefix' => 'wp_',            // テーブル名のプレフィックス(オプション)
        'encoding' => 'utf8',         // エンコード
    );
}

データベースの切替

データベースの切替は各モデルごとに設定できます。
$useDbConfigを指定することで違うデータベースへ接続することができます。指定無しの場合は$defaultのデータベースへ接続されます。

class Post extends AppModel {
    var $name = 'Post';
    var $useTable = 'posts';
    var $useDbConfig = 'wordpress';
}

**テーブル名のプレフィックスにwp_を設定しているため、このPostモデルでは、wp_postsテーブルにアクセスすることができます。

  • このエントリーをはてなブックマークに追加

関連記事

テキストから自動的にリンクを付与「autoLink」と除去「stripLinks」

Textヘルパーには、テキスト処理に関する便利な機能があります。ユーザによる投稿などを表示する際に、URLが貼り付けられている場合に自動的にリンクを付けてくれるautoLinkや、逆に、リンクが貼られ

テキストから指定文字数で抜粋「excerpt」「truncate」「tail」

Textヘルパーには、コントローラーから受けとったテキストデータを切り取り表示してくれるヘルパーが用意されています。先頭もしくは末尾から指定文字数を切り取ってくれる「truncate」「tail」、指

Captchaプラグイン「Captcha Component & Helper」

Captchaプラグインを実装してみました。 ダウンロードはこちら 解凍して、このようになるようにそのままappディレクトリ下に置いてください。 app/Controller/Compone

テキストから指定文字をハイライト「highlight」・配列をリストに展開「toList」・二重改行を<p>タグへ変換「autoParagraph」

Textヘルパーの「highlight」は、テキスト内の指定文字をハイライトしてくれます。検索結果の表示などに使用できそうです。デモ highlight テキスト内の指定文字ハイライト表示しま

「isUnique」バリデーション

「isUnique」は、特定カラムの一意性を検証してくれるメソッドです。 2.5.6からは、複数フィールドにまたがる一意性検証にも対応するようになったようです。 使用方法 p

シンプルに設置できる数字Captcha「MathCaptcha」

スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。この「MathCapthca」は非常にシンプルに設置できます。 ダウンロードはこちらから。 MathC

Cakeログ 出力フォーマット カスタマイズ

Cakeログの出力はFileLogクラスのwriteメソッドで行われます。今回は、出力のフォーマットの変更をいくつか試してみました。 既存のライブラリを上書き(オーバーライド)する方法 wri

ユーザエージェントを取得

Windows XPサポート終了に伴い、移行を促すために有効な手段としてユーザのブラウザやOSの情報を取得して行動を促すというのがあると思います。 グローバル関数「env」でuser-agent

Comment

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

*

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

    PAGE TOP ↑