CakePHPの履歴

マニュアル
http://book.cakephp.org/

API
http://api.cakephp.org/

使い方

Component使え!

逆引きリファレンス

Viewテンプレート内で別のテンプレートを呼びたい。

libs.view.php View#render($action, $layout, $file) を使う

// 変数の設定
$this->hogehoge = time();
$this->render('yourTemplateName', false);

Session使ってflashMessage

コントローラで

$this->helpers = array(..., 'Session', ...);
function myaction(){
  $this->Session->setFlash('更新したよ');
}


ビューで

// echoいらない
$session->flash()

ページャ、ページング

アクションで

$this->paginate = array('limit' => 20, 'order' => 'hoge');
// $conditionsはfindと同じでよろし
$this->paginate('User', $conditions);

ビューで
$paginator->params() で各パラメータ取得。
page: 現在のページ番号
defaults.limit: 1ページあたりの項目数
count: 総項目数
current: 現在ページに何件表示されているか
pageCount: 総ページ数

実際これだけじゃ足りなくて自前実装になる。Zend_Paginatorの方がまだ楽かも。

DBからの取得

CakePHPモデルは「arrayベース」。全部arrayでやりとりする。Railsのパクりということで、ActiveRecordパターンかと思ったら、なかそうではなかった。テーブルデータゲートウェイパターンか。

// 一件取得
$data = $this->User->findById($id);
// データはこんな風になってる。(モデル名含むので注意!)
// $data = array(
//   'User' => 
//    array('id' => 1, 'name' => 'akkun', 'gender' => 'male')
// );


// gender=maleだけ全件取得
$data = $this->User->find('all', 
   array('conditions' => array('gender' => 'male')));

DBからの取得からの更新

$data = $this->User->findById($id);
$data['User']['name'] = 'john smith';
$this->User->save($data);

フォームでPOST

ビューで

$form->create('User', array('url' => '/user/hoge'))

アクションで

if (!empty($this->data['User'])){
  // POSTの場合
}

発行されたSQLクエリを見たい

core.php のココを2に。

  Configure::write('debug', 2);

ちなみに、

  • 0:メッセージ表示しない
  • 1: Error,Warningを表示
  • 2: 1加え、SQL出力
  • 3: 2に加え、コントローラーをダンプ

ビューやコントローラで任意のアクションのrender結果を得る

echo $this->requestAction('users/show', array('return')

http://api.cakephp.org/class/object#method-ObjectrequestActi...
requestActionはObjectが持ってるので、ビューやコントローラに限らず、だいたいどこでも使える。

cakeコマンド

cd /my/cake/app_folder
../cake/console/cake [command]


cake bake でscaffolding
前もってテーブルは作っとく。

schema

cake schema generate    # 現在のDB構造をconfig/sql/schema.phpに反映
cake schema run create  # schema.phpからテーブルを作成
cake schema run update  # schema.phpの状態にDB構造を反映
cake schema run update [table_name]
cake schema run update -s 2 # 特定のスナップショット