php – Laravel 5 Eloquent:如何获取正在执行的原始sql? (带有绑定数据)

我试图弄清楚如何获取正在执行的原始SQL查询,包括其中的绑定数据.这是我得到的:

\DB::connection()->enableQueryLog();
$query = \DB::getQueryLog();
$lastQuery = end($query);

以下是结果:

array(3) {
  ["query"]=>
  string(57) "select * from `table_1` where `field_1` = ? limit 1"
  ["bindings"]=>
  array(1) {
    [0]=>
    string(34) "xyz"
  }
}

那么如何获得像这样的完整SQL查询的转储(旧的老式方式)?

select * from `table_1` where `field_1` = 'xyz' limit 1

谢谢

解决方法:

在您的路线中添加文件夹:

\Event::listen('Illuminate\Database\Events\QueryExecuted', function ($query) {
    Log::info( json_encode($query->sql) );
    Log::info( json_encode($query->bindings) );
    Log::info( json_encode($query->time)   );
});

Log :: info()==>将在您的storage / logs / laravel.log文件中记录SQL查询

var_dump()==>将显示在API调用输出

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...