Heim > Backend-Entwicklung > PHP-Tutorial > Warum ist mein DB::getQueryLog()-Array in Laravel 5 leer?

Warum ist mein DB::getQueryLog()-Array in Laravel 5 leer?

Susan Sarandon
Freigeben: 2024-11-13 14:14:02
Original
646 Leute haben es durchsucht

Why is my DB::getQueryLog() Array Empty in Laravel 5?

Leeres DB::getQueryLog()-Array in Laravel 5: Beheben des Problems

Das Abfrageprotokoll von Laravel 5 ist standardmäßig deaktiviert, was dazu führt ein leeres Array beim Aufruf von DB::getQueryLog(). Um dieses Problem zu beheben, aktivieren Sie das Abfrageprotokoll explizit mit einer der folgenden Methoden:

  • Abfrageprotokoll programmgesteuert aktivieren:

    DB::enableQueryLog();
    print_r(DB::getQueryLog());
    Nach dem Login kopieren
  • Veranstaltung anmelden Zuhörer:

    DB::listen(
      function ($sql, $bindings, $time) {
          // Process and store query log data
      }
    );
    Nach dem Login kopieren

Zusätzliche Tipps:

  • Mehrere DB-Verbindungen:
    Aktivieren und Abrufen von Abfrageprotokollen für bestimmte Zwecke Verbindungen:

    DB::connection('my_connection')->enableQueryLog();
    print_r(
     DB::connection('my_connection')->getQueryLog()
    );
    Nach dem Login kopieren
  • Middleware-Ansatz:
    Abfrageprotokollierung in der Handle-Methode der Middleware aktivieren und Protokolle in der Terminate-Methode abrufen:

    class BeforeAnyDbQueryMiddleware
    {
      // Enable query logging before DB operations
      public function handle($request, Closure $next)
      {
          DB::enableQueryLog();
          return $next($request);
      }
    
      // Retrieve query log after DB operations
      public function terminate($request, $response)
      {
          dd(DB::getQueryLog());
      }
    }
    Nach dem Login kopieren
  • CLI Ausführung:
    Abfrageprotokollierung im artisan.start-Ereignis aktivieren:

    $app['events']->listen('artisan.start', function(){
      \DB::enableQueryLog();
    });
    Nach dem Login kopieren

Überlegungen zum Speicher:

Laravel-Stores Protokolle im Speicher abfragen. Um eine übermäßige Speichernutzung zu vermeiden:

  • Aktivieren Sie die Abfrageprotokollierung nur zum Debuggen.
  • Verwenden Sie den folgenden Code, um die Abfrageprotokollierung nur in der Entwicklung zu aktivieren Umgebung:

    if (App::environment('local')) {
      // The environment is local
      DB::enableQueryLog();
    }
    Nach dem Login kopieren

Referenzen:

  • [Laravel Query Logging](https://laravel.com/docs/ 5.0/database#query-logging)

Das obige ist der detaillierte Inhalt vonWarum ist mein DB::getQueryLog()-Array in Laravel 5 leer?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage