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
- Serializer factory with Django Rest Framework by julio 5 months, 3 weeks ago
- Image compression before saving the new model / work with JPG, PNG by Schleidens 6 months, 1 week ago
- Help text hyperlinks by sa2812 7 months, 1 week ago
- Stuff by NixonDash 9 months, 1 week ago
- Add custom fields to the built-in Group model by jmoppel 11 months, 2 weeks ago
Comments
Please login first before commenting.