Laravel 实时监听打印 SQL

创建监听器

1
php artisan make:listener QueryListener --event=Illuminate\Database\\Events\\QueryExecuted

打开 app/ProvidersEventServiceProvider.php ,在$listen中添加

1
2
3
4
5
6
7
protected $listen = [
'Illuminate\Database\Events\QueryExecuted' => [
'App\Listeners\QueryListener,
]
];
#头部添加
use App\Listeners\QueryListener;

打开QueryListener文件

1
2
3
4
5
6
7
8
public function handle (QueryExecuted $event)
{
if (env('APP_ENV', 'production') == 'local') {
$sql = str_replace("?", "'%s'", $event->sql);
$log = vsprintf($sql, $event->bindings);
Log::info($log);
}
}