如何从QuerySet对象中获取Django将在数据库上使用的SQL ?我试图调试一些奇怪的行为,但我不确定什么查询将到数据库。
当前回答
当我使用Django 1.4.4时,接受的答案对我不起作用。返回的不是原始查询,而是query对象的引用:<django.db.models.sql.query。查询0x10a4acd90>的对象。
下面返回查询:
>>> queryset = MyModel.objects.all()
>>> queryset.query.__str__()
其他回答
当我使用Django 1.4.4时,接受的答案对我不起作用。返回的不是原始查询,而是query对象的引用:<django.db.models.sql.query。查询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调试工具栏项目使用它在页面上以一种简洁的方式呈现查询。
打印查询集的查询属性。
>>> queryset = MyModel.objects.all()
>>> print(queryset.query)
SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"
作为其他答案的替代方案,django-devserver将SQL输出到控制台。
这个中间件将输出每个SQL查询到您的控制台,有颜色高亮和执行时间,这对我来说是非常宝贵的优化一些棘手的请求
http://djangosnippets.org/snippets/290/
推荐文章
- 获取对象的Django管理url
- 比较两个SQL Server数据库(模式和数据)的最佳工具是什么?
- 在SQL中,如何在范围中“分组”?
- 选项(RECOMPILE)总是更快;为什么?
- 如何制作好的可复制的熊猫例子
- 2个数字表的余弦相似度
- 如何从熊猫的两列形成元组列
- 如何读一个文本文件到一个列表或数组与Python
- 设置数据库从单用户模式到多用户
- Django可选url参数
- 在matplotlib上为散点图中的每个系列设置不同的颜色
- oracle中的RANK()和DENSE_RANK()函数有什么区别?
- 如何加载一个tsv文件到熊猫数据框架?
- 从csv文件创建字典?
- 我如何提高一个响应禁止在django