複数データベースの追加と切替
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
複数データベースの追加と切替 #cakephp #model #trick876
http://t.co/peYDrgE0HS