Laravel记录SQL日志信息
前言
Laravel
的 ORM
是相当好用的。
同时,因为 Laravel
内部帮我们做了不少东西,很多操作都是无感知的,只知道输入什么,输出什么。
有时候,为了能够更好的分析问题,我们需要通过一些运行日志来帮助我们。
方法1
官方推荐 传送门
<?php
namespace App\Providers;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
DB::listen(function ($query) {
Log::info($event->sql . ' bind: ' . json_encode($event->bindings));
});
}
}
方法2
使用 EventServiceProvider
注册。
<?php
namespace App\Providers;
use App\Listeners\QueryListener;
use Illuminate\Database\Events\QueryExecuted;
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
class EventServiceProvider extends ServiceProvider
{
/**
* The event listener mappings for the application.
*
* @var array
*/
protected $listen = [
QueryExecuted::class => [
QueryListener::class
],
];
}
实现 QueryListener
:
<?php
namespace App\Listeners;
use Illuminate\Support\Facades\Log;
use Illuminate\Database\Events\QueryExecuted;
/**
* Log Query
*/
class QueryListener
{
/**
* Handle the event.
*
* @param QueryExecuted $event
*
* @return void
*/
public function handle(QueryExecuted $event)
{
if (!$event->sql) {
return;
}
Log::info($event->sql . ' bind: ' . json_encode($event->bindings));
}
}
最终的结果是一致的。
最后
终于可以看到执行的 SQL
了,也可以根据 SQL
来了解 Laravel
大致的一个实现方式。
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!