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,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值