Laravel监听数据库访问,打印SQL的例子

吾爱主题 阅读:134 2021-09-14 15:21:00 评论:0

增加一个helper函数

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 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" ;      });    }

在需要开始监听数据库访问的位置添加代码

?
1 2 DB::connection()->enableQueryLog(); // 打开query log sql_dump();

sql语句会被打印到标准输出。

以上这篇Laravel监听数据库访问,打印SQL的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/u010205879/article/details/50848597

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容