分享一个在laravel中打印执行的sql语句的函数
标签搜索

分享一个在laravel中打印执行的sql语句的函数

十年
2023-06-08 / 0 评论 / 45 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2023年06月08日,已超过923天没有更新,若内容或图片失效,请留言反馈。

放在在sql语句执行前即可打印

<?php
function getLastSql()
{
    DB::listen(function ($sql) {
        foreach ($sql->bindings as $i => $binding) {
            if ($binding instanceof \DateTime) {
                $sql->bindings[$i] = $binding->format('\'Y-m-d H:i:s\'');
            } else {
                if (is_string($binding)) {
                    $sql->bindings[$i] = "'$binding'";
                }
            }
        }
        $query = str_replace(array('%', '?'), array('%%', '%s'), $sql->sql);
        $query = vsprintf($query, $sql->bindings);
        dump($query);
        echo '<br />';
    });
}
本文共 12 个字数,平均阅读时长 ≈ 1分钟
0

评论 (0)

取消