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
- Template tag - list punctuation for a list of items by shapiromatron 10 months, 2 weeks ago
- JSONRequestMiddleware adds a .json() method to your HttpRequests by cdcarter 10 months, 3 weeks ago
- Serializer factory with Django Rest Framework by julio 1 year, 5 months ago
- Image compression before saving the new model / work with JPG, PNG by Schleidens 1 year, 6 months ago
- Help text hyperlinks by sa2812 1 year, 7 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.