Pretty print SQL of query sets

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

  1. DebugFooter middleware with Pygments sql syntax highlighting by monolar 3 years, 8 months ago
  2. print SQL statements by zuzelvp 2 years ago
  3. SQL Log To Console Middleware by davepeck 2 years, 6 months ago
  4. Format transition middleware by limodou 4 years, 11 months ago
  5. Serializing booleans correctly when doing dumpdata from a MySQL database using Django 0.96 by chrj 3 years, 6 months ago

Comments

peterbe (on May 5, 2009):

You might want to wrap this with something so that this doesn't get used in non-development mode. For example:

if not settings.DEBUG:
    def print_sql(*__):
        pass

#

canassa (on August 6, 2010):

This should work in Django 1.2:

def print_sql(qs):
    q = qs.query.__str__()
    print sqlparse.format(q, reindent=True, keyword_case='upper')

#

(Forgotten your password?)