laravel 添加sql日志

时间:2021-06-25 17:07:22   收藏:0   阅读:0

laravel 打印sql语句非常的麻烦而且不方便,所以就想弄一个sql日志来方便调试排除

首先到 

EventServiceProvider.php (监听文件)
里 赋值日志开关常数
define(‘SQL_LOG‘, env(‘SQL_LOG‘, false));
然后到
$listen 里增加
SQL_LOG ? \Illuminate\Database\Events\QueryExecuted::class : ‘‘ => [
\App\Listeners\ExampleListener::class // 这个类就是要我们自己写的监听方法
],

然后到
ExampleListener里写写入sql 的方法
public function handle(QueryExecuted $event)
{
$sql = str_replace("?", "‘%s‘", $event->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);
}
评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!