从Django QuerySet获取SQL

我如何获得Django将在QuerySet对象的数据库上使用的SQL? 我试图debugging一些奇怪的行为,但我不知道什么查询将数据库。 谢谢你的帮助。

您打印queryquery属性。

 >>> 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,那么您的所有查询都会被logging下来,并且您可以通过访问connection.queries来获取它们:

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

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

使用Django 1.4.4时,我接受的答案并不适用于我。 而不是原始查询,返回对Query对象的引用: <django.db.models.sql.query.Query object at 0x10a4acd90>

以下返回查询:

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

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

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

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