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
関連記事
-
-
Formヘルパーのinputタグのdiv/labelなどの設定
Formヘルパーのinputではデフォルトでは以下のようにdivで囲われて、labelが付与されて出力されます。 CSSのフレームワークなどであらかじめ決まったスタイルがある場合に便利に作られていま
-
-
selectボックスを実装
今まで、selectボックスのgroupを作成するのにSet::Combineを使用していましたが、意外と簡単にできることに気付いてしまったので、ご紹介。(自分だけ知らなかったことに気付いた と言った
-
-
HttpSocketを使用してリクエスト送信
CakePHPには、Webサービスへのリクエスト送信のためのHttpSocketクラスが用意されています。 HttpSocket get HTTP GETリクエストを発行します。デモ H
-
-
RSSフィードの取得
コンロトーラ public function getrssfeed() { try { $newsItems = $this->Rss->read( 'http://
-
-
CakePHP 2.x インストール
現在まで私が商用・非商用にリリースしているCakePHPアプリケーションは全て1.3.xベースで作成しています。 まだまだロードマップ的には大丈夫そうですが、お客さん向けに納品しているアプリケーショ
-
-
CakePHP インストール時エラーの対処
CakePHPインストール時に出くわすであろうエラーの原因と対処方法についてまとめてみました。前提として、WebサーバはApache、データベースはMySQLとしています。 Timezone未設
-
-
パス定数と変更方法やURLの取得
CakePHPは基本的にはディレクトリそのまま配置することで構築が可能ではありますが、設定パスを変更することでセキュリティに考慮した構成にすることや運用性をもたせたものにすることが可能になります。
-
-
Js/Cssファイルの読み込みや出力する方法
CakePHPのHTMLヘルパーにはjsファイルやcssファイルを読み込むためのメソッドが用意されています。ファイルを読み込むのに加えて、出力先を複数指定できるようになっています。 また、インライン
-
-
DebugKitを導入
定番のブログチュートリアルをこなして、定番のDebugKitを導入してみました。 2.3からはCakePHPインストール直後に以下のように導入を推奨するような警告メッセージが表示されるようになりまし
-
-
コントローラ内でバリデーション処理を呼び出す
CakePHPでは、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。
- PREV
- WYSIWYGエディタを実装
- NEXT
- Twenty Twelve 投稿日・投稿者を非表示に
Comment
“CakePHP 2.x | SQLクエリーをログに出力する” http://t.co/5UN8AQQM0Z
CakePHP 2.x | SQLクエリーをログに出力する http://bit.ly/1gIixep