从Django QuerySet获取SQL

时间:2010-09-20 02:11:54

标签: python sql django django-queryset

如何从QuerySet对象获取Django将在数据库中使用的SQL?我正在尝试调试一些奇怪的行为,但我不确定哪些查询会进入数据库。谢谢你的帮助。

5 个答案:

答案 0 :(得分:392)

您打印查询集的query属性。

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

答案 1 :(得分:50)

易:

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 debug toolbar项目使用它以整齐的方式在页面上显示查询。

答案 2 :(得分:35)

使用Django 1.4.4时,

The accepted answer对我不起作用。而不是原始查询,返回了对Query对象的引用:<django.db.models.sql.query.Query object at 0x10a4acd90>

以下内容返回了查询:

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

答案 3 :(得分:9)

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

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

答案 4 :(得分:9)

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