我正在使用django中的原始SQL进行复杂查询来解决一些注释问题。 实际的查询有许多左连接已转换为子查询,以解决Django中的一个主要错误。 https://code.djangoproject.com/ticket/10060
鉴于
fields = ['shift__adminFee',
'shift__rosterSlot__adminFee',
'shift__taxi__rosterGroup__adminFee',
'shift__driver__adminFee']
query = `''select table.id, "table_shift"."adminFee"
, "table_rosterslot"."adminFee"
, "table_rostergroup"."adminFee"
, "table_driver"."adminFee" from table
left join ( select table_id, sum(amount) amount_sum from related_table group by table_id ) related_table
on table.id = related_table.table_id
...
( more inner joins and tables to support the above fields )
'''
rawQuerySet = Table.objects.raw(q)
返回RawQuerySet。
RawQuerySet运行良好......它填充相关模型并提供正确的注释结果。
然而,RawQuerySet不支持返回元组列表。
我查看了源文件,该文件在本地项目中是'env / lib / python2.7 / site-packages / django / db / models / query.py' 但我还不明白它,我有一个结果可以产生。
所以不要做result_as_list_of_tuples = query.values_list(* fields) 我做了类似
的事情 results_as_list_of_tuples = []
for result in query:
shift = result.shift
eventSchedule = shift.eventSchedule
rosterSlot = shift.rosterSlot
taxi = shift.taxi
rosterGroup = taxi.rosterGroup
data = []
...
# the following is one line. I broke it up because it didn't format correctly.
data.extend([
shift.adminFee
,rosterSlot.adminFee
,rosterGroup.adminFee
,driver.adminFee]
)
...
results_as_list_of_tuples.append(tuple(data))
如何从Django RawQuerySet中获取元组列表 类似results_as_list_of_tuples = values_list(raw_query_set,* fields)
答案 0 :(得分:1)
您可以通过 RawQuerySet
属性从 columns
获取列名列表。可以通过以下方式从原始查询集创建 values_list
迭代器:
def raw_queryset_as_values_list(raw_qs):
columns = raw_qs.columns
for row in raw_qs:
yield tuple(getattr(row, col) for col in columns)
属性columns
没有记录,但是很稳定。