exu*_*ero 279 python sql django django-queryset
如何从QuerySet对象获取Django将在数据库中使用的SQL?我正在尝试调试一些奇怪的行为,但我不确定哪些查询会进入数据库.谢谢你的帮助.
jpw*_*tts 422
您打印查询集的query属性.
>>> queryset = MyModel.objects.all()
>>> print(queryset.query)
SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"
Run Code Online (Sandbox Code Playgroud)
Mik*_*iak 50
简单:
print my_queryset.query
Run Code Online (Sandbox Code Playgroud)
例如:
from django.contrib.auth.models import User
print User.objects.filter(last_name__icontains = 'ax').query
Run Code Online (Sandbox Code Playgroud)
还应该提到的是,如果你有DEBUG = True,那么你的所有查询都会被记录下来,你可以通过访问connection.queries来获取它们:
from django.db import connections
connections['default'].queries
Run Code Online (Sandbox Code Playgroud)
在Django的调试工具栏项目使用此提出查询页面上在一个整洁的方式.
Hak*_* B. 41
使用Django 1.4.4时,接受的答案对我不起作用.而不是原始查询,返回了对Query对象的引用:<django.db.models.sql.query.Query object at 0x10a4acd90>.
以下返回了查询:
>>> queryset = MyModel.objects.all()
>>> queryset.query.__str__()
Run Code Online (Sandbox Code Playgroud)
Gui*_*vin 10
这个中间件将每个SQL查询输出到您的控制台,具有颜色突出显示和执行时间,这对于我优化一些棘手的请求非常宝贵
http://djangosnippets.org/snippets/290/
| 归档时间: |
|
| 查看次数: |
142274 次 |
| 最近记录: |