博客
关于我
Laravel5:sql语句的正确打印方式
阅读量:806 次
发布时间: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/

    你可能感兴趣的文章
    MYSQL sql语句针对数据记录时间范围查询的效率对比
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql sysbench测试安装及命令
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    MySQL Troubleshoting:Waiting on query cache mutex
    查看>>
    mysql union orderby 无效
    查看>>
    mysql v$session_Oracle 进程查看v$session
    查看>>
    mysql where中如何判断不为空
    查看>>
    mysql where中如何判断不为空
    查看>>
    MySQL Workbench 使用手册:从入门到精通
    查看>>
    MySQL Workbench 数据库建模详解:从设计到实践
    查看>>
    MySQL Workbench 数据建模全解析:从基础到实践
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>