如何查看 Laravel 5 的所有数据库请求

WBOY
Freigeben: 2016-06-20 12:28:19
Original
910 Leute haben es durchsucht

说明

Laravel 有一套特别灵活的数据库操作方案,此文介绍一个简单的方法来获取到所有的 SQL 语句。

1. 开启 QueryLog

我们需要先调用以下方法来告诉框架可以开始记录 SQL 请求了:

DB::enableQueryLog();
Nach dem Login kopieren

我们可以考虑把此段代码放置于 BeforeMiddleware中间件里(文档见 这里),使用以下命令生成 BeforeMiddleware:

php artisan make:middleware BeforeMiddleware
Nach dem Login kopieren

上面命令会生成 app/Http/Middleware/BeforeMiddleware.php文件,在此文件的 handle方法内:

public function handle($request, Closure $next){    DB::enableQueryLog();    return $next($request);}
Nach dem Login kopieren

2. 获取 QueryLog

开启了 QueryLog以后,我们就可以使用以下方法来获取到执行过 SQL:

$queries = DB::getQueryLog();
Nach dem Login kopieren

如果想要获取所有的 QueryLog的话,可以将代码放置于 AfterMiddleware中。

使用以下命令创建 AfterMiddleware(文档见 这里):

php artisan make:middleware AfterMiddleware
Nach dem Login kopieren

会生成 app/Http/Middleware/AfterMiddleware.php文件,在此文件的 handle方法内:

public function handle($request, Closure $next){    $response = $next($request);    //retrieve all executed queries    $queries = DB::getQueryLog();    //code to save query logs in a file    //return response    return $response;    }
Nach dem Login kopieren
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!