从Django QuerySet中获取SQL

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

235127 次浏览

打印queryset的query属性。

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

容易:

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调试工具栏项目使用它在页面上以简洁的方式呈现查询。

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

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

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

当我使用Django 1.4.4时,公认的答案不能为我工作。返回的不是原始查询,而是对query对象的引用:<django.db.models.sql.query.Query object at 0x10a4acd90>

下面返回查询:

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