ホームページ > PHPフレームワーク > Laravel > LaravelでのSQLデバッグのヒント

LaravelでのSQLデバッグのヒント

Guanhui
リリース: 2020-06-12 17:56:19
転載
3219 人が閲覧しました

LaravelでのSQLデバッグのヒント

何らかの理由で、Laravel DebugBar を使用できない場合は、この記事が役立つかもしれません。

Laravel アプリケーションの最適化は、N 1 問題を解決するだけではありません。 Laravel DebugBar を適切に使用すると、モデルのメモリ使用量や SQL クエリの適時性などの問題に対する合理的な解決策が得られます。

Laravel DebugBar を使いたくない、または何らかの理由 (インターフェイスベースのアプリケーションの開発など) で Laravel DebugBar を使用できない場合は、データベース リスナーが良い方法になるでしょう。 SQL クエリをログに記録します。

これは運用環境とテスト環境に同様に適用され、env または config を通じて有効にするかどうかを簡単に制御できます。

使用方法:

これを AppServiceProvider の起動メソッドに追加します

 if (env("SQL_DEBUG_LOG"))
    {
        DB::listen(function ($query) {
            Log::debug("DB: " . $query->sql . "[".  implode(",",$query->bindings). "]");
        });
    }
ログイン後にコピー

運用環境で使用する場合は、構成に含めることをお勧めします。設定情報を env に保存すると、この設定情報をキャッシュできます (キャッシュする必要があります)。

別の問題は、SQL 呼び出し自体が失敗すると例外がスローされ、呼び出しが成功する前に待機することです。 DB::listen はログを記録せず、リスナーに戻る前に例外が発生します。

推奨チュートリアル: 「PHP チュートリアル 」 「Laravel チュートリアル

以上がLaravelでのSQLデバッグのヒントの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:learnku.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート