本文实例讲述了Laravel框架实现的记录SQL日志功能。分享给大家供大家参考,具体如下:
在项目开发过程中或者是性能优化中,经常会有要查看执行sql的情况,然而Laravel日志默认不记录执行sql。好在留有相关接口,我们可以很方便的就是想SQl日志功能。
在
新建SqlListener监听器 [
'App\Listeners\EventListener',],// 新增SqlListener监听QueryExecuted
'Illuminate\Database\Events\QueryExecuted' => [
'App\Listeners\SqlListener',];
方法1
,手动创建,在
方法2
,使用命令行创建,命令如下
php artisan make:listener SqlListener -e=QueryExecuted
在handle方法中编写记录sql的业务逻辑,如:
sql);
$log = vsprintf($sql,$event->bindings);
$log = '[' . date('Y-m-d H:i:s') . '] ' . $log . "\r\n";
$filepath = storage_path('logs\sql.log');
file_put_contents($filepath,$log,FILE_APPEND);
// 这里也可以直接用Log::info() 里的函数,只是这样会和其他调试信息掺在一起。
// 如果要用Log里的函数,别忘记了引入Log类。
}
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》及《》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。