laravel开启sql日志

在AppServiceProvider.php中的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'";
                        }
                    }
                }

                // Insert bindings into query
                $query = str_replace(array('%', '?'), array('%%', '%s'), $sql->sql);

                $query = vsprintf($query, $sql->bindings);

                // Save the query to file
                $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);
            }
        );

猜你喜欢

转载自blog.csdn.net/m0_37678007/article/details/120530837