Laravel监听数据库访问,打印SQL的例子
增加一个helper函数
if(!function_exists('sql_dump')){ functionsql_dump() { \DB::listen(function($sql){ $i=0; $bindings=$sql->bindings; $rawSql=preg_replace_callback('/\?/',function($matches)use($bindings,&$i){ $item=isset($bindings[$i])?$bindings[$i]:$matches[0]; $i++; returngettype($item)=='string'?"'$item'":$item; },$sql->sql); echo$rawSql,"\n
\n"; }); } }
在需要开始监听数据库访问的位置添加代码
DB::connection()->enableQueryLog();//打开querylog sql_dump();
sql语句会被打印到标准输出。
以上这篇Laravel监听数据库访问,打印SQL的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。