CakePHPクッキング

データキャッシュ

開発環境:CakePHP2.5.1

CakePHPにはデータキャッシュやビューキャッシュなどのキャッシュ機能がついています。
ビューキャッシュについては以下を参考にしてください。
http://cakephpクッキング.jp/archives/331

キャッシュの設定

まずはキャッシュの設定を行います。
設定場所は、app/Config/core.php。
Cache::configの設定内容がいくつかコメント内に記載されているので、ファイルキャッシュを行う場合は、下記のコードをコメント外に記載します。

<?php
Cache::config('default', array(
	'engine' => 'File', //[required]
	'duration' => 3600, //[optional]
	'probability' => 100, //[optional]
	'path' => CACHE, //[optional] use system tmp directory - remember to use absolute path
	'prefix' => 'cake_', //[optional]  prefix every cache file with this string
	'lock' => false, //[optional]  use file locking
	'serialize' => true, //[optional]
	'mask' => 0664, //[optional]
));
?>

保存する場所や保存時間などはオプション設定で変更ができます。

SQLキャッシュ

モデルで呼び出すSQLをキャッシュするにはモデル内で次のようにします。

<?php
public function newest() {
    $model = $this;
    return Cache::remember('newest_posts', function() use ($model){
        return $model->find('all', array(
            'order' => 'Sample.created desc',
            'limit' => 10
        ));
    });
}
?>

これをコントローラー側呼び出すとSQLを発行せず、キャッシュからデータを出力してくれます。
キャッシュファイル名はCache::configのprefix+第一引数となります。

WordPressとCakePHPの共存

サイトを作るのに便利なWordPress。プラグインも数多く用意されて

サイトマップの作成方法

Googleのウェブマスターツールに渡すためのサイトマップの作成方法で

INSERTしたIDを取得する

データを保存した後にINSERTされたデータのIDを使って何かの処理を

ファイルの存在確認やフォルダー内のファイル一覧取得

特定のファイルの存在を確認したい場合や特定のフォルダー内にあるファイル

リンクの最後に常にスラッシュをつける方法

URLの最後に常にスラッシュをつけるかつけないかを統一する方法は、UR

countやsumを使う時のフィールド名を指定する

CakePHPでcountやsumなどを使う場合、ちょっとした工夫が必

Formの便利な使い方

問い合わせフォームや会員機能など、WEBサイトを作る際に必ず必要になる

ヘルパーをオーバーライドする

CakePHPで便利な機能が詰まったヘルパーですが、時々もう少しこうだ

特定の時だけSQLの条件を追加するならSet::mergeを使う

SQLの条件を追加したい時に使うのがarray_mergeなどですが、

ページネーションではDISTINCTではなく、GROUP BYを使う

重複したデータを省く時に使うDISTINCTですが、ページ送りで使う時

Model内で別のModelを呼び出す

モデル内で別のモデルを使いたいケースがあった場合、次のようにすることで

CakePHPでGoogleAnalyticsAPIを使う

CakePHPでGoogleAnalyticsを使う方法について見てい

独自のfindを定義するfindMethods

findをより便利に、よりスッキリ書くのに、findMethodsを使

TCPDFを使ってCakePHPでPDFを作成

CakePHPでPDFを作成するには幾つかの方法がありますが、今回はT

JavaScriptをコードの最下部に配置

SEOの観点からJavaScriptのコードは一番下に記述したいところ

無限スクロールをさせる

TwitterやFacebookのタイムラインを見ていて、ページの下に

PHPExcelの導入

ExcelにDBのデータを表示して一覧を作ったり、請求書などのフォーマ

Warning: SplFileInfo::openFile〜の警告が表示されたら

ShellとWEBの両方で同一のModelを呼び出す時に「Warnin

連結されていないデータを抽出

通常、テーブルを連結してデータを取得するには、アソシエーションを利用し

データを取得する

データを取得したい時に少し変わった条件で取得したい場合があります。

PAGE TOP ↑