Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL dalam Django?

Patricia Arquette
Lepaskan: 2024-10-17 17:27:03
asal
468 orang telah melayarinya

How Can I Log All SQL Queries in Django?

Melog Pertanyaan SQL dalam Django

Soalan ini mencari kaedah untuk merekod semua pertanyaan SQL yang dilaksanakan oleh aplikasi Django, termasuk yang berasal daripada tapak pentadbir. Tugasnya ialah untuk mencipta fail log pusat (cth., all-sql.log) untuk menangkap pernyataan SQL ini.

Mengkonfigurasi PEMLOG:

Untuk mencapai ini, gabungkan coretan berikut dengan medan LOGGING dalam tetapan anda.py:

<code class="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>
Salin selepas log masuk

Penjelasan:

  • Tetapkan 'level': 'DEBUG' untuk menangkap semua Pertanyaan SQL, tanpa mengira keterukan mereka.
  • Gunakan 'pengendali': ['console'] untuk mengubah hala pertanyaan SQL ke output konsol.
  • Konfigurasikan 'pembalak': {'django.db. backends': {'level': 'DEBUG'}} untuk log semua pertanyaan SQL yang dilaksanakan melalui Django ORM.

Nota:

Penyelesaian ini berasal daripada jawapan @acardenas89. Ia memastikan bahawa semua pertanyaan SQL yang dilaksanakan Django ditulis pada konsol apabila aplikasi berada dalam mod nyahpepijat.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL dalam Django?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan