通过event记录sql

Posted brady-wang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了通过event记录sql相关的知识,希望对你有一定的参考价值。

providers

EventServiceProvider.php 添加
protected $listen = [
        ‘IlluminateDatabaseEventsQueryExecuted‘ => [
            ‘AppListenersQueryListener‘
        ] ,
    ];

  执行php artisan event:generate

会生成 

QueryListener.php文件
<?php

namespace AppListeners;

use IlluminateDatabaseEventsQueryExecuted;
use IlluminateQueueInteractsWithQueue;
use IlluminateContractsQueueShouldQueue;
use IlluminateSupportFacadesLog;

class QueryListener
{
    /**
     * Create the event listener.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Handle the event.
     *
     * @param  QueryExecuted  $event
     * @return void
     */
    public function handle(QueryExecuted $event)
    {

        $sql = str_replace("?", "‘%s‘", $event->sql);
        $log[‘sql‘] = vsprintf($sql, $event->bindings);
        Log::info(date("Y-m-d H:i:s")."(". $log[‘sql‘]).")";
    }
}

  bootstrap文件添加

$app->register(AppProvidersEventServiceProvider::class);

以上是关于通过event记录sql的主要内容,如果未能解决你的问题,请参考以下文章

用于从 cloudkit 检索单列的代码模式/片段

js经常用到的代码片段

sql [SQL查询片段]用于在命令行或通过R和其他工具使用SQL的快速代码段#tags:sql,R,text processing,命令li

laravel 利用监听器进行sql语句记录

解决移动端报错:Unable to preventDefault inside passive event listener due to target being treated as……(代码片段

使用BroadcastReciever传递Intent.EXTRAS