从 Django 查询集中获取 SQL

发布于 2024-09-24 10:16:06 字数 78 浏览 3 评论 0原文

如何从 QuerySet 对象获取 Django 将在数据库上使用的 SQL?我正在尝试调试一些奇怪的行为,但我不确定哪些查询将发送到数据库。

How do I get the SQL that Django will use on the database from a QuerySet object? I'm trying to debug some strange behavior, but I'm not sure what queries are going to the database.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

稀香 2024-10-01 10:16:06

您打印查询集的 query 属性。

>>> queryset = MyModel.objects.all()
>>> print(queryset.query)
SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"

You print the queryset's query attribute.

>>> queryset = MyModel.objects.all()
>>> print(queryset.query)
SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"
我恋#小黄人 2024-10-01 10:16:06

简单:

print(my_queryset.query)

例如:

from django.contrib.auth.models import User
print(User.objects.filter(last_name__icontains = 'ax').query)

还应该提到的是,如果您有 DEBUG = True,那么您的所有查询都会被记录下来,您可以通过访问 connection.queries 来获取它们:

from django.db import connections
connections['default'].queries

django 调试工具栏 项目使用它以简洁的方式在页面上呈现查询。

Easy:

print(my_queryset.query)

For example:

from django.contrib.auth.models import User
print(User.objects.filter(last_name__icontains = 'ax').query)

It should also be mentioned that if you have DEBUG = True, then all of your queries are logged, and you can get them by accessing connection.queries:

from django.db import connections
connections['default'].queries

The django debug toolbar project uses this to present the queries on a page in a neat manner.

神妖 2024-10-01 10:16:06

接受的答案在使用 Django 1.4.4 时对我不起作用。返回对 Query 对象的引用,而不是原始查询:

返回的查询如下:

>>> queryset = MyModel.objects.all()
>>> queryset.query.__str__()

The accepted answer did not work for me when using Django 1.4.4. Instead of the raw query, a reference to the Query object was returned: <django.db.models.sql.query.Query object at 0x10a4acd90>.

The following returned the query:

>>> queryset = MyModel.objects.all()
>>> queryset.query.__str__()
愿与i 2024-10-01 10:16:06

这个中间件会将每个 SQL 查询输出到您的控制台,并带有颜色突出显示和执行时间,这对于我优化一些棘手的请求来说非常宝贵

http://djangosnippets.org/snippets/290/

This middleware will output every SQL query to your console, with color highlighting and execution time, it's been invaluable for me in optimizing some tricky requests

http://djangosnippets.org/snippets/290/

孤单情人 2024-10-01 10:16:06

作为其他答案的替代方案, django-devserver 将 SQL 输出到控制台。

As an alternative to the other answers, django-devserver outputs SQL to the console.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文