Install sqlparse with easy_install sqlparse and then you can easily debug the SQL like this:
def view(request):
data = MyModel.objects.filter(something__very=complex)
print_sql(data)
...
Inspired by Simon Willison
1 2 3 4 5 6 | import sqlparse
def print_sql(qs):
q = qs.query.as_sql()
statement = q[0] % q[1]
print sqlparse.format(statement, reindent=True, keyword_case='upper')
|
More like this
- New Snippet! by Antoliny0919 4 days, 15 hours ago
- Add Toggle Switch Widget to Django Forms by OgliariNatan 2 months, 3 weeks ago
- get_object_or_none by azwdevops 6 months, 2 weeks ago
- Mask sensitive data from logger by agusmakmun 8 months, 1 week ago
- Template tag - list punctuation for a list of items by shapiromatron 1 year, 10 months ago
Comments
You might want to wrap this with something so that this doesn't get used in non-development mode. For example:
#
This should work in Django 1.2:
#
Please login first before commenting.