Bagaimanakah Saya Melihat Pertanyaan SQL Mentah yang Dilaksanakan oleh Django?

Mary-Kate Olsen
Lepaskan: 2024-11-01 21:19:02
asal
676 orang telah melayarinya

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php.cn
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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!