这个问题在这里已有答案:
如何从QuerySet对象获取Django将在数据库中使用的SQL?我正在尝试调试一些奇怪的行为,但我不确定哪些查询会进入数据库 . 谢谢你的帮助 .
这个中间件将每个SQL查询输出到您的控制台,具有颜色突出显示和执行时间,这对于我优化一些棘手的请求非常宝贵
http://djangosnippets.org/snippets/290/
作为其他答案的替代方法,django-devserver将SQL输出到控制台 .
您打印查询集的 query 属性 .
query
>>> queryset = MyModel.objects.all() >>> print queryset.query SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"
The accepted answer在使用Django 1.4.4时对我不起作用 . 而不是原始查询,返回了对Query对象的引用: <django.db.models.sql.query.Query object at 0x10a4acd90> .
<django.db.models.sql.query.Query object at 0x10a4acd90>
以下返回了查询:
>>> queryset = MyModel.objects.all() >>> queryset.query.__str__()
简单:
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项目使用它以一种简洁的方式在页面上显示查询 .
5 回答
这个中间件将每个SQL查询输出到您的控制台,具有颜色突出显示和执行时间,这对于我优化一些棘手的请求非常宝贵
http://djangosnippets.org/snippets/290/
作为其他答案的替代方法,django-devserver将SQL输出到控制台 .
您打印查询集的
query
属性 .The accepted answer在使用Django 1.4.4时对我不起作用 . 而不是原始查询,返回了对Query对象的引用:
<django.db.models.sql.query.Query object at 0x10a4acd90>
.以下返回了查询:
简单:
例如:
还应该提到的是,如果你有DEBUG = True,那么你的所有查询都会被记录下来,你可以通过访问connection.queries来获取它们:
django debug toolbar项目使用它以一种简洁的方式在页面上显示查询 .