Detaillierte Erläuterung der Django SQL-Abfrageprotokollierung
Django ist ein beliebtes Python-Webframework zum Erstellen datenbankgesteuerter Anwendungen. Um eine optimale Leistung sicherzustellen und Datenbankprobleme zu beheben, ist es häufig erforderlich, alle von einer Anwendung ausgeführten SQL-Abfragen zu protokollieren. Diese Anleitung führt Sie Schritt für Schritt durch die Implementierung dieser Protokollierung in Django.
Standortabfrage-Protokollierungscode
Um SQL-Abfragen zu protokollieren, müssen Sie die settings.py
-Datei Ihres Django-Projekts bearbeiten. Suchen Sie in dieser Datei das Wörterbuch LOGGING
und ändern Sie es gemäß dem folgenden Codeausschnitt:
<code class="language-python">LOGGING = { 'version': 1, 'filters': { 'require_debug_true': { '()': 'django.utils.log.RequireDebugTrue', } }, 'handlers': { 'console': { 'level': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.StreamHandler', } }, 'loggers': { 'django.db.backends': { 'level': 'DEBUG', 'handlers': ['console'], } } }</code>
Integrierte Protokollierungskonfiguration
Nachdem das bereitgestellte Code-Snippet mit dem LOGGING
-Wörterbuch zusammengeführt wurde, protokolliert Django automatisch alle SQL-Abfragen in der Konsole. Um Abfragen in eine separate Datei umzuleiten (z. B. all-sql.log
), müssen Sie dem Abschnitt handlers
einen Dateihandler hinzufügen. Das Folgende ist ein Beispiel für die geänderte Konfiguration:
<code class="language-python">LOGGING = { 'version': 1, 'filters': { 'require_debug_true': { '()': 'django.utils.log.RequireDebugTrue', } }, 'handlers': { 'console': { 'level': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.StreamHandler', }, 'file': { 'level': 'DEBUG', 'class': 'logging.FileHandler', 'filename': '/path/to/all-sql.log', # 请替换为您的日志文件路径 } }, 'loggers': { 'django.db.backends': { 'level': 'DEBUG', 'handlers': ['file'], } } }</code>
Denken Sie daran, /path/to/all-sql.log
durch Ihren tatsächlichen Protokolldateipfad zu ersetzen. Nach Abschluss der Konfiguration werden alle Datenbankabfragen in der angegebenen Datei protokolliert.
Das obige ist der detaillierte Inhalt vonWie protokolliere ich SQL-Abfragen effektiv in Django?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!