Django - 在注释查询集后获取值列表

时间:2017-08-29 13:03:23

标签: django django-orm

我有一个像这样的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查询

1 个答案:

答案 0 :(得分:1)

Queryset是惰性的,而.values_list仍然返回一个queryset对象。要评估它,只需将其转换为列表:

rs = qs2.filter(id__in=list(max_id_qs))