统计接口sql语句

//开始记录
app(\Illuminate\Database\ConnectionInterface::class)->enableQueryLog();

//....过程代码

//输出
 print_r(app(\Illuminate\Database\ConnectionInterface::class)->getQueryLog());die();

最近开发完,开始做一些优化,想要看一个接口与数据库的交互,找到了这个方法。第一次一个接口140多条sql,第二次几十条(加了缓存),这应该还好吧

应该是laravel记录了连接数据库的sql语句吧,这样方便一点,虽然mysql应该也有日志。

本作品采用《CC 协议》,转载必须注明作者和本文链接
放肆疯狂,委婉洒脱。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 4

App/Providers/AppServiceProvider.phpboot 方法中

DB::listen(function ($event) {
    $sql = $event->sql;
    $bindings = $event->bindings;
    $time = $event->time;

    $bindings = array_map(function ($binding) {
        if (is_string($binding)) {
            return "'{$binding}'";
        } elseif ($binding instanceof \DateTime) {
            return $binding->format("'Y-m-d H:i:s'");
        }

        return $binding;
    }, $bindings);

    $sql = str_replace("%", "%%", $sql); // SQL DATE_FORMAT函数中%Y-%m-%d中,会被sprintf转义
    $sql = str_replace("?", "%s", $sql);
    $sql = sprintf($sql, ...$bindings);
    logger()->debug("SQL log:", ['time' => $time . "ms", 'sql' => $sql]);
});
2年前 评论
Neilyozの鱼不浪 (作者) 2年前
bigdaxin (楼主) 2年前
Tomo11111

如果是 laravel 6 以上版本,建议使用 Telescope 调试工具。

2年前 评论
bigdaxin (楼主) 2年前

下载一个debugbar,点哪里看哪里

2年前 评论
bigdaxin (楼主) 2年前
DB::enableQueryLog(); // Enable query log
dd(DB::getQueryLog()); // Show results of log

这个写法是不是一样?我不知道,你可以试试。

2年前 评论
bigdaxin (楼主) 2年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!