php教程 Laravel 中 SQL Debug 小技巧

 所属分类:php教程

 浏览:108次-  评论: 0次-  更新时间:2022-05-27
描述:这是一篇php教程 Laravel 中 SQL Debug 小技巧的说明内容,如果你想学习查找类似的文章,可以进入php教程获得最新优质资料。 基于某些...
这是一篇php教程 Laravel 中 SQL Debug 小技巧的说明内容,如果你想学习查找类似的文章,可以进入php教程获得最新优质资料。

基于某些原因,你不能使用 Laravel DebugBar ,这篇文章可能会帮到你。

针对 Laravel 应用的优化远远不止消除 N+1 问题那么简单。合理的使用 Laravel DebugBar 可以对模型内存的使用以及 SQL 查询时效等问题给出合理的解决方案。

可能你并不喜欢使用 Laravel DebugBar,或者基于某些原因而不能使用(比如基于接口应用的开发),那么 Database Listener 将会是个不错的方法,他将记录你的 SQL 查询到日志。

这在生产环境与测试环境同样适用,你可以很简单的通过 env 或者 config 控制它的启用与否。

如何使用:

将此添加到你的 AppServiceProvider 的启动方法中

 if (env("SQL_DEBUG_LOG"))
    {
        DB::listen(function ($query) {
            Log::debug("DB: " . $query->sql . "[".  implode(",",$query->bindings). "]");
        });
    }

如果你在生产环境中使用它的话,我建议你可以把 config 中的配置信息放到 env 中,然后你还可以(并且应该)缓存这个 config 信息

我发现另一个问题是假如 sql 调用本身失败,会抛出一个异常,在成功调用前其监听的 DB::listen 并不会进行记录,并且该异常会在返回到监听之前发生。

推荐教程:《PHP教程》《Laravel教程》

以上就是Laravel 中 SQL Debug 小技巧的详细内容,更多请关注zzsucai网其它相关文章!

 标签:
积分说明:注册即送10金币,每日签到可获得更多金币,成为VIP会员可免金币下载! 充值积分充值会员更多说明»

讨论这个素材(0)回答他人问题或分享使用心得奖励金币

〒_〒 居然一个评论都没有……

表情  文明上网,理性发言!