Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL dalam Django?

Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL dalam Django?

Patricia Arquette
Patricia Arquetteasal
2024-10-17 17:27:03387semak imbas

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>

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!

Kenyataan:
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