SQLクエリーをログに出力する
SQLのクエリーをデバッグするには、Debug Kitを使用すればできますが、デバッグログと一緒に出したいのでやり方を調査してみました。
別々のログやビューでみるのもいいですが、秒単位で実行される処理もどちらが先に実行されたのかなどわかりやすくなるので、いいかなと個人的に思っています。
明示的に実行SQLをデバッグする
モデル操作(find, save, deleteなど)の後に以下のコードを挿入すると実行SQLを(デバッグ)ログに出力させることができます。
$this->log( $this->[Model]->getDataSource()->getLog(), LOG_DEBUG);
出力先は自由に設定して下さい。
暗黙的に実行SQLをデバッグする
DataSourcesをオーバーライドさせます。
MySQLの場合
1. MysqlLog.phpを作成(名前は自由に)
// \app\Model\Datasource\Database\MysqlLog.php
<?php
App::uses( 'Mysql', 'Model/Datasource/Database');
class MysqlLog extends Mysql {
function logQuery( $sql, $params = array()) {
parent::logQuery( $sql);
if (Configure::read('Cake.logQuery')) {
$this->log( $this->_queriesLog, LOG_DEBUG); // SQLの実行詳細
// $this->log( $sql, LOG_DEBUG); // SQLクエリーのみ
}
}
}
?>
2. datasourceを変更
// \app\Config\database.php
// 'datasource' => 'Database/Mysql',
'datasource' => 'Database/MysqlLog',
3. 出力するフラグを設定
出力させるさせないを設定します。以下を追加すると出力されるようになります。
// \app\Config\core.php Configure::write( 'Cake.logQuery', 1);
上記を削除すれば、出力させなくできます。
参考
Vladimir Bilyov - Logging sql queries into file in CakePHP 2
関連記事
-
-
ユーザ登録(仮登録・メール・本登録)
以前1.3版で投稿した「ユーザ登録」処理の2.x版を作成しました。フローは同じで以下のようにします。 1. メールアドレス・パスワードでユーザ登録 2. この時点では仮登録として、本登録用のU
-
-
radioボタンを実装
Radioボタンの実装は、セレクトボックスとほぼ同じです。 個人的にはラジオボタンをすすんで使用することは少ないのですが、2択くらいの選択肢であれば非常に便利ですよね。 今回は、その実装方法 デモ
-
-
テーブルからランダムにデータを取り出す(find)
CakePHPでテーブルから特定件数のレコードをランダムに取得するには以下のように指定するとできます。 $this->data = $this->Bulkdata->find( 'all',
-
-
Markdown Plugin
「Markdown CakePHP Plugin」は、MarkDown書式をレンダリングしてくれるビューヘルパーです。MarkDownについて勉強しているうちに出会ったので試し打ちです。 ダウンロー
-
-
パス定数と変更方法やURLの取得
CakePHPは基本的にはディレクトリそのまま配置することで構築が可能ではありますが、設定パスを変更することでセキュリティに考慮した構成にすることや運用性をもたせたものにすることが可能になります。
-
-
コントローラ内でバリデーション処理を呼び出す
CakePHPでは、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。
-
-
バリデーション前後に処理を追加できる「beforeValidate」「afterValidate」
CakePHPでは、「beforeValidate」「afterValidate」というバリデーション処理の前後で追加の処理を実装できるコールバック関数が用意されています。 beforeVali
-
-
checkボックスを実装
selectボックスに引き続いてcheckボックスの実装方法をおさらいしてみます。 コードは、CakePHP 2と1.3両方で実装可能です。デモ モデルは、こちらも以下 CREATE TA
-
-
独自のバリデーションルールを作成
CakePHPで組み込みバリデーションルールをつくる方法は、正規表現を定義する方法と独自メソッドを定義する方法の2つがあるようです。 参考 Custom Validation Rules 正規
-
-
HttpSocketを使用してリクエスト送信
CakePHPには、Webサービスへのリクエスト送信のためのHttpSocketクラスが用意されています。 HttpSocket get HTTP GETリクエストを発行します。デモ H
- PREV
- WYSIWYGエディタを実装
- NEXT
- Twenty Twelve 投稿日・投稿者を非表示に



Comment
“CakePHP 2.x | SQLクエリーをログに出力する” http://t.co/5UN8AQQM0Z
CakePHP 2.x | SQLクエリーをログに出力する http://bit.ly/1gIixep