Laravel如何将SQL查询事件记录到日志文件中?
- 内容介绍
- 文章标签
- 相关推荐
本文共计231个文字,预计阅读时间需要1分钟。
简单改写伪原创以下开头内容,内容本身保持不变,不要试图图解答案,不要啰嗦,不超过100字,直接输出结果:
在本文中,我们将讨论如何处理laravel中的查询日志记录。 假设你在阅读本文时已经非常熟悉laravel。 laravel可以选择将所有在当前请求中运行的查询记录在内存中。 有一些方法可用于此。
查询记录
如果,你想要将日志文件保存在 storage/logs 目录中。
需要更新: app/Providers/AppServiceProvider.php 里的 boot() 函数。
<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; use DB; class AppServiceProvider extends ServiceProvider { /** * Bootstrap any application services. * * @return void */ public function boot() { // 新增代码 DB::listen(function($query) { Log::info( $query->sql, $query->bindings, $query->time ); }); } /** * Register any application services. * * @return void */ public function register() { // } }
这样我们就可以记录执行过的SQL语句了,开发过程中也方便我们进行调试。
本文共计231个文字,预计阅读时间需要1分钟。
简单改写伪原创以下开头内容,内容本身保持不变,不要试图图解答案,不要啰嗦,不超过100字,直接输出结果:
在本文中,我们将讨论如何处理laravel中的查询日志记录。 假设你在阅读本文时已经非常熟悉laravel。 laravel可以选择将所有在当前请求中运行的查询记录在内存中。 有一些方法可用于此。
查询记录
如果,你想要将日志文件保存在 storage/logs 目录中。
需要更新: app/Providers/AppServiceProvider.php 里的 boot() 函数。
<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; use DB; class AppServiceProvider extends ServiceProvider { /** * Bootstrap any application services. * * @return void */ public function boot() { // 新增代码 DB::listen(function($query) { Log::info( $query->sql, $query->bindings, $query->time ); }); } /** * Register any application services. * * @return void */ public function register() { // } }
这样我们就可以记录执行过的SQL语句了,开发过程中也方便我们进行调试。

