跳至正文

Laravel框架打印sql

  • PHP

1、第一种方法

use DB;

function getSql(){
	DB::connection()->enableQueryLog();
	//执行的语句
	$sql = DB::getQueryLog();
	dd($sql);
}

2、第二种方法
打开这个文件

在boot方法里插入以下代码

public function boot()
{
    \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);

            $logFile = fopen(
                storage_path('logs' . DIRECTORY_SEPARATOR . date('Y-m-d') . '_query.log'),
                'a+'
            );
            fwrite($logFile, date('Y-m-d H:i:s') . ': ' . $query . PHP_EOL);
            fclose($logFile);
        }
    );
}

执行语句就会将sql生成在日志文件中
vim App/Storage/logs/年-月-日_query.log
就能完美查看运行的sql了

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注