Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Melihat Pertanyaan SQL Mentah yang Dilaksanakan oleh Django?

Bagaimanakah Saya Melihat Pertanyaan SQL Mentah yang Dilaksanakan oleh Django?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-01 21:19:02806semak imbas

How Do I View the Raw SQL Queries Executed by Django?

Keterlihatan Pertanyaan SQL Django

Untuk melihat pertanyaan SQL mentah yang dilaksanakan oleh Django, anda boleh merujuk kepada Soalan Lazim dokumentasi Django untuk soalan khusus ini .

Menggunakan django.db.connection.queries

Satu kaedah ialah menggunakan atribut django.db.connection.queries, yang mengekalkan senarai pertanyaan SQL yang dilaksanakan . Untuk memaparkannya:

<code class="python">from django.db import connection
print(connection.queries)</code>

Memeriksa Pertanyaan Set Pertanyaan

Set Pertanyaan juga mempunyai atribut pertanyaan yang mengandungi pertanyaan yang akan dilaksanakan. Untuk mengaksesnya:

<code class="python">from django.db import models
print(MyModel.objects.filter(name="my name").query)</code>

Nota Penting

Adalah penting untuk ambil perhatian bahawa output pertanyaan bukan SQL yang sah. Ini kerana:

"Django tidak pernah benar-benar menginterpolasi parameter: ia menghantar pertanyaan dan parameter secara berasingan kepada penyesuai pangkalan data, yang melaksanakan operasi yang sesuai."

Menetapkan Semula Pertanyaan

Jika anda perlu menetapkan semula senarai pertanyaan yang dilaksanakan untuk, sebagai contoh, menilai bilangan pertanyaan dalam jangka masa tertentu, gunakan fungsi reset_queries daripada django.db:

<code class="python">from django.db import reset_queries
from django.db import connection

reset_queries()
# Execute your query here
print(connection.queries)</code>

Atas ialah kandungan terperinci Bagaimanakah Saya Melihat Pertanyaan SQL Mentah yang Dilaksanakan oleh 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