关于python:从Django QuerySet获取SQL

Getting the SQL from a Django QuerySet

本问题已经有最佳答案,请猛点这里访问。

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


打印查询集的query属性。

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


容易的:

1
print my_queryset.query

例如:

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

还应注意,如果debug=true,则会记录所有查询,您可以通过访问connection.queries来获取这些查询:

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

Django调试工具栏项目使用它以一种整洁的方式在页面上显示查询。


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

以下返回了查询:

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


作为其他答案的替代,Django DevServer将SQL输出到控制台。


这个中间件将把每一个SQL查询输出到您的控制台,用颜色突出显示和执行时间,这对于我优化一些棘手的请求是非常有价值的。

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