laravel 添加sql日志

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);
}
posted @ 2021-06-25 10:12  をもって剣を制す  阅读(103)  评论(0编辑  收藏  举报