今天小编就为大家分享一篇Laravel监听数据库访问,打印SQL的例子,有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
增加一个helper函数
if ( ! function_exists('sql_dump')) {
function sql_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++;
return gettype($item) == 'string' ? "'$item'" : $item;
}, $sql->sql);
echo $rawSql, "\n<br /><br />\n";
});
}
}
在需要开始监听数据库访问的位置添加代码
DB::connection()->enableQueryLog(); // 打开query log
sql_dump();
sql语句会被打印到标准输出。
以上这篇Laravel监听数据库访问,打印SQL的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程学习网。
编程基础网
本文标题为:Laravel监听数据库访问,打印SQL的例子
基础教程推荐
猜你喜欢
- PHP中的输出缓冲控制详解 2023-06-03
- PHP树形结构tree类用法示例 2022-12-15
- PHP如何将头像图片转换圆形图片 2023-08-30
- CentOS 7 编译安装PHP7 2023-09-02
- php fread函数使用方法总结 2023-01-19
- 在laravel中实现事务回滚的方法 2023-02-22
- php+mysql+ajax 局部刷新点赞/取消点赞功能(每个账号只点赞一次) 2023-04-24
- PHP设计模式之状态模式定义与用法详解 2022-10-12
- PHP5.0 TIDY_PARSE_FILE缓冲区溢出漏洞的解决方案 2022-11-26
- 解析PHP中Exception异常机制 2023-06-13
