Login

custom sql without table names

Author:
robharvey
Posted:
May 18, 2007
Language:
Python
Version:
.96
Tags:
sql postgres
Score:
1 (after 5 ratings)

Keeps database table names out of custom SQL code, but still allows for correct parameter passing in the execute function. (psycopg doesn't substitute table or field names, only data, in the execute function)

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
    # dict indexed to model names
    tables = {'str':'%s'}
    for x in ModelOne, ModelTwo:
        tables[x._meta.object_name] = x._meta.db_table

    cursor = connection.cursor()
    ex_str =  """\
    select field1, field2, sum(field3) from %(ModelOne)s where date between %(str)s and %(str)s 
    group by field1, field2
    """ % tables
    cursor.execute(ex_str, dates)
    sumt = cursor.fetchall()

More like this

  1. SQL Function Decorator by proc 6 years, 9 months ago
  2. fast table flush without raw SQL by dsblank 5 years, 5 months ago
  3. Custom SQL via subquery by drg006 8 years ago
  4. post_migrate handler to load initial SQL after migrating with south by stingydrone 4 years, 4 months ago
  5. SQLLoggerMidleware + infobar by robvdl 7 years, 4 months ago

Comments

Please login first before commenting.