TP6记录报错的SQL语句

在使用 ThinkPHP6 时,你会发现,即使开启了记录SQL,在执行到一句错误的SQL查询时,并没有跟踪到错误的SQL记录。在日志中只有这么一条前后不搭的报错:

[2021-12-26T21:29:44+08:00][error] [10501]SQLSTATE[42S22]: Column not found: 1054 Unknown column 'distict' in 'field list'

这很摸不到头脑,于是改进一下,至少知道运行的SQL是神马玩意。

修改一下 vendor/topthink/think-orm/src/db/PDOConnection.php 第 795 行左右位置

修改前:

            if ($e instanceof \PDOException) {
                throw new PDOException($e, $this->config, $this->getLastsql());
            } else {
                throw $e;
            }

修改后:

            if ($e instanceof \PDOException) {
                $this->db->log( $this->getLastsql() .' => '. $e->getMessage() , 'error');
                throw new PDOException($e, $this->config, $this->getLastsql());
            } else {
                throw $e;
            }

这里就增加了一行日志记录($this->db->log(xxxxxx)),把错误语句和错误信息都记录下来。

当然也可以增加 debug_backtrace() 函数把错误跟踪也写进去,但thinkPHP6的错误跟踪实在是太多了,还是简单点好,知道哪里错了就行了。

 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值