Laravel 查看SQL操作记录
未知
2019-11-26 09:20:53
0

方法一:临时打印操作记录

DB::connection()->enableQueryLog();   # 开启执行的日志
执行的sql语句    # 这里是用laravel模型查询的语句
var_dump(DB::getQueryLog());   # 打印模型查询执行的sql语句

方法二:输出SQL信息到日志文件
打开项目文件app/Providers/AppServiceProvider.php

     /**
     * 引导服务。
     *
     * @return void
     */


在boot函数中添加以下代码

            \DB::listen(function ($query) {
                $tmp = str_replace('?', '"'.'%s'.'"', $query->sql);
                $qBindings = [];
                foreach ($query->bindings as $key => $value) {
                    if (is_numeric($key)) {
                        $qBindings[] = $value;
                    } else {
                        $tmp = str_replace(':'.$key, '"'.$value.'"', $tmp);
                    }
                }
                $tmp = vsprintf($tmp, $qBindings);
                $tmp = str_replace("\\", "", $tmp);
                \Log::info(' execution time: '.$query->time.'ms; '.$tmp."\n\n\t");

            }
        );

保存,再次执行SQL操作,SQL操作就会记录到Laravel的日志中,日志目录位于storage/logs。一般是laravel-2019-12-12.log

 
 

sql

相关内容

MySQL触发器最佳实践与...
摘要: 本文介绍了MySQL触发器的最佳实践和案例分析,包括明确...
2025-02-09 12:46:40
MySQL触发器实例:订单...
MySQL触发器实例:通过订单处理,展示如何利用触发器自动更新库存...
2025-02-09 12:00:46
MySQL索引的最佳实践策...
MySQL索引最佳实践:明确需求,合理设计索引类型,避免过度索引,...
2025-02-09 11:23:43
优化MySQL查询性能的关...
摘要: 本文介绍了MySQL中索引的概念、作用及创建、使用和优化...
2025-02-09 11:00:40
MySQL索引策略与最佳实...
MySQL索引策略与最佳实践:合理设计数据库结构,选择合适列进行索...
2025-02-09 10:46:40
索引在MySQL中的最佳实...
MySQL索引最佳实践:明确需求,避免过度索引,选择合适类型,利用...
2025-02-09 10:23:41

热门资讯

Laravel 5.5 .No... 创建了新的laravel项目后, 运行提示:No application encryption ke...
生成随机字符唯一标识符guid... /** * @param $length * @return string * 生成随机字符串 */...
tp5 jquery判断手机端... application--common.php中添加如下代码 //函数作用是判断用户打开的是手机端还...
php 打印date函数出现错... 问题描述: 我使用的是phpstudy,在练习时间函数的时候,打印出现在的时间,date(Y-m-d...
Laravel 查看SQL操作... 方法一:临时打印操作记录 DB::connection()-enableQueryLog(); # ...
php函数substr_rep... php函数substr_replace从某个位置替换或删除或插入字符串
layui缩略图 div class=layui-form-item label class=layui-form-l...
object json转化为数... //调用api 程序,通知商户订单异常 20200314 public function callt...
php银行开放平台接口:pfx... 问题描述: 对接易通银行,他们的服务开放平台是java开发,而我的是php,现在需要php版本的SD...
Laravel 引入自定义类库... 强烈建议引入的类 都是含有命名空间的,这样使用起来就不会出现重名的情况。!!当然,没有命名空间也可以...