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

说明

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

1. 开启 QueryLog

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

DB::enableQueryLog();

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

php artisan make:middleware BeforeMiddleware

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

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

2. 获取 QueryLog

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

$queries = DB::getQueryLog();

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

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

php artisan make:middleware AfterMiddleware

会生成 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;   

}

Practice makes perfect.

本帖已被设为精华帖!
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 13
Summer

@enma72056 文件顶部 use DB;

2年前

如果使用中间件记录 sql 语句,一个问题就是,如果中途发生了异常,在上一个中间件就已经处理了请求,就不会到达这个 sql中间件了,就不能记录 sql 语句了。
所以 是不是使用 监听器 DB::listen,更好 ?

2年前

我是用mysql服务器记录所有的查询日志 。。。

2年前

5.3取消了,用EloquentORM->toSql() 替代

2年前

没看懂 后置中间件 和 前置中间件的区别是什么?

2年前

前后置目的是什么有什么用啊,curd有没有前后置方法,像更新之前,插入之后类是的?

1年前

  • 请注意单词拼写,以及中英文排版,参考此页
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`, 更多语法请见这里 Markdown 语法
  • 支持表情,使用方法请见 Emoji 自动补全来咯,可用的 Emoji 请见 :metal: :point_right: Emoji 列表 :star: :sparkles:
  • 上传图片, 支持拖拽和剪切板黏贴上传, 格式限制 - jpg, png, gif
  • 发布框支持本地存储功能,会在内容变更时保存,「提交」按钮点击时清空
  请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!