博客
关于我
Laravel5:sql语句的正确打印方式
阅读量:794 次
发布时间:2023-01-30

本文共 956 字,大约阅读时间需要 3 分钟。

为了在Laravel中更方便地记录完整的SQL语句,而不是分开显示语句和参数,我们可以使用数据库监听器来捕获并格式化每个查询。以下步骤展示了如何实现这一点:

  • 开启查询日志记录:首先,我们需要使用DB::listen()方法来跟踪数据库查询。此外,我们还可以自定义日志记录路径和格式。
  • \DB::listen(function (\Illuminate\Database\Statement $sql) {    // 替换占位符    $query = str_replace(['%'], ['%%'], $sql->sql);        // 格式化参数    foreach ($sql->bindings as $i => $binding) {        if ($binding instanceof \DateTime) {            $sql->bindings[$i] = $binding->format('\'Y-m-d H:i:s\'');        } elseif (is_string($binding)) {            $sql->bindings[$i] = "'$binding'";        }    }        // 格式化查询    $query = vsprintf($query, $sql->bindings);        // 写入日志文件    $logPath = storage_path('logs/' . date('Y-m-d')) . '_query.log';        $logFile = fopen($logPath, 'a+');    fwrite($logFile, "[{$date}] - {$query}\n", date('Y-m-d H:i:s'));    fclose($logFile);});
    1. 配置服务提供器:将上述代码添加到AppServiceProviderboot方法中,这将确保每次数据库查询都被记录到日志文件中。
    2. 这样,完成后,我们就能在storage/log目录下找到相应的查询日志文件,里面将包含完整的SQL查询语句及其参数值,便于验证和调试。

    转载地址:http://xfgyk.baihongyu.com/

    你可能感兴趣的文章
    leetcode题解189-旋转数组
    查看>>
    leetcode题解191-位1的个数
    查看>>
    leetcode题解20-有效的括号
    查看>>
    leetcode题解200-岛屿数量
    查看>>
    leetcode题解206-反转链表
    查看>>
    leetcode题解227-基本计算器 II
    查看>>
    leetcode题解236-二叉树的最近公共祖先
    查看>>
    leetcode题解25-K个一组翻转链表
    查看>>
    leetcode题解26-删除数组的重复项
    查看>>
    leetcode题解279-完全平方数
    查看>>
    leetcode题解3-无重复字符的最长子串
    查看>>
    leetcode题解34-在排序数组中查找元素的第一个和最后一个位置
    查看>>
    leetcode题解347-前 K 个高频元素
    查看>>
    leetcode题解4-寻找两个正序数组的中位数
    查看>>
    leetcode题解41-缺失的第一个正数原来如此简单
    查看>>
    leetcode题解434-字符串中的单词数(双指针经典)
    查看>>
    leetcode题解46-全排列
    查看>>
    leetcode题解48-旋转图像
    查看>>
    leetcode题解5-最长回文子串
    查看>>