laravel 打印sql运行记录

简介:

app/Providers/AppServiceProvider.php

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<?php
 
namespace  App\Providers;
 
use  Blade;
use  Illuminate\Support\ServiceProvider;
use  Illuminate\Support\Facades\DB;
use  Illuminate\Contracts\Logging\Log;
 
class  AppServiceProvider  extends  ServiceProvider
{
     /**
      * Bootstrap any application services.
      *
      * @return void
      */
     public  function  boot()
     {
         Blade::directive( 'currency' function  ( $x ) {
             return  "<?php if (round((float)$x, 2)) { echo number_format(round((float)$x, 2), 2); } ?>" ;
         });
 
         Blade::directive( 'currency_with_zero' function  ( $x ) {
             return  "<?php echo number_format(round((float)$x, 2), 2); ?>" ;
         });
 
         Blade::directive( 'selector' function  ( $x ) {
             return  "<?php echo 'ac-' . strtr($x, '.', '-'); ?>" ;
         });
         DB::listen(
 
             function  ( $sql ) {
                 // $sql is an object with the properties:
                 //  sql: The query
                 //  bindings: the sql query variables
                 //  time: The execution time for the query
                 //  connectionName: The name of the connection
 
                 // To save the executed queries to file:
                 // Process the sql and the bindings:
                 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);
 
                 \Log::debug( $query );
                 \Log::debug( $sql ->time .  ' ms'  . PHP_EOL . PHP_EOL);
             }
         );
     }
 
     /**
      * Register any application services.
      *
      * @return void
      */
     public  function  register()
     {
         //
     }
}









本文转自 hgditren 51CTO博客,原文链接:http://blog.51cto.com/phpme/1958744,如需转载请自行联系原作者
目录
相关文章
|
SQL 数据库
PowerDesigner导出SQL脚本运行注释出现乱码问题
PowerDesigner导出SQL脚本运行注释出现乱码问题
577 0
|
SQL Java 数据库连接
springboot-maven项目+jpa 运行过程中执行resources下sql脚本文件-ClassPathResource和ScriptUtils.executeSqlScript的使用
springboot-maven项目+jpa 运行过程中执行resources下sql脚本文件-ClassPathResource和ScriptUtils.executeSqlScript的使用
961 0
springboot-maven项目+jpa 运行过程中执行resources下sql脚本文件-ClassPathResource和ScriptUtils.executeSqlScript的使用
|
8月前
|
前端开发 JavaScript Java
基于springboot+vue开发的校园食堂评价系统【源码+sql+可运行】【50809】
本系统基于SpringBoot与Vue3开发,实现校园食堂评价功能。前台支持用户注册登录、食堂浏览、菜品查看及评价发布;后台提供食堂、菜品与评价管理模块,支持权限控制与数据维护。技术栈涵盖SpringBoot、MyBatisPlus、Vue3、ElementUI等,适配响应式布局,提供完整源码与数据库脚本,可直接运行部署。
474 6
基于springboot+vue开发的校园食堂评价系统【源码+sql+可运行】【50809】
|
SQL 关系型数据库 MySQL
拖.sql文件到cmd中运行
通过命令行工具cmd来运行SQL脚本文件,包括登录MySQL数据库、选择数据库和使用source命令执行脚本文件的步骤。
224 0
|
SQL 弹性计算 资源调度
云服务器 ECS产品使用问题之bin/spark-sql --master yarn如何进行集群模式运行
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
SQL 关系型数据库 分布式数据库
PolarDB产品使用问题之sql运行报错是神么原因
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
SQL 存储 缓存
一条 SQL 查询语句是如何运行?
本文详细剖析了SQL语句在MySQL中的执行流程,涵盖客户端、Server层及存储引擎层。Server层包括连接器、查询缓存、分析器、优化器与执行器等核心组件。连接器管理连接与权限校验,查询缓存加速查询,分析器负责词法与语法分析,优化器提升SQL性能,执行器调用存储引擎接口。了解这些流程有助于深入理解MySQL内部机制及其优化原理。
366 0
|
SQL 分布式计算 大数据
MaxCompute操作报错合集之执行多条SQL语句时,使用同一个实例来运行,遇到报错,该如何解决
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
303 1
|
SQL 分布式计算 DataWorks
DataWorks操作报错合集之重新上传后只有SQL无法运行,而Python可以正常运行,是什么导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
SQL 分布式计算 DataWorks
MaxCompute产品使用问题之如何通过临时查询功能来书写和运行SQL语句
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
315 0
下一篇
开通oss服务