Home > Backend Development > Python Tutorial > How Can I Inspect the SQL Queries Executed by Django?

How Can I Inspect the SQL Queries Executed by Django?

Barbara Streisand
Release: 2024-11-02 16:59:03
Original
856 people have browsed it

How Can I Inspect the SQL Queries Executed by Django?

How to Inspect SQL Queries in Django

Want to know the SQL statements that Django runs when executing a query? The answer is simple:

1. Find the answer from the documentation
The FAQ section of the Django documentation provides a straightforward answer:

2. Access the database Connection
can access the SQL query list through django.db.connection.queries:

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

3. View the Queryset object
The Queryset object has a query attribute , which contains the query to be executed:

<code class="python">print(MyModel.objects.filter(name="my name").query)</code>
Copy after login

Note: The query output by is not valid SQL. The reason is:

"Django never actually interpolates parameters: it sends the query and parameters separately to the database adapter, which performs the appropriate operations."

(Taken from Django bug report #17741)

Therefore, do not send query output directly to the database.

Reset queries
If you need to reset a query, such as to see the number of queries run in a given time period, you can use django.db.reset_queries:

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

reset_queries()
# 运行你的查询
print(connection.queries)
>>> []</code>
Copy after login

The above is the detailed content of How Can I Inspect the SQL Queries Executed by Django?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template