我有一个像这样的Django代码:
max_id_qs = qs1.values('parent__id').\
annotate(max_id = Max('id'),).\
values_list('max_id', flat = True)
问题在于,当我在这样的过滤器中使用max_id_qs
时:
rs = qs2.filter(id__in = max_id_qs)
查询转换为以下结构的MySQL查询:
select ... from ... where ... and id in (select max(id) from ...)
而预期的结果应该是
select ... from ... where ... and id in [2342, 233, 663, ...]
换句话说,我在MySQL查询中得到子查询而不是整数列表,这大大减慢了查找速度。让我感到惊讶的是,我认为Django的values_list
返回一个值列表。
所以问题是,如何重写代码以使用整数而不是id in (select ... from...)
子查询来实现所需的MySQL查询
答案 0 :(得分:1)
Queryset是惰性的,而.values_list仍然返回一个queryset对象。要评估它,只需将其转换为列表:
rs = qs2.filter(id__in=list(max_id_qs))