在Django中优化带注释的查询

时间:2013-08-25 15:14:44

标签: sql django django-orm

我正在尝试将这个简单的SQL查询转换为Django可以处理的内容:

SELECT *
FROM location AS a
WHERE a.travel_distance = (
    SELECT MAX(travel_distance)
    FROM location AS b
    WHERE b.person_id = a.person_id
)
ORDER BY a.travel_distance DESC

这基本上是取得所有行进的位置,只选择包含最大行程距离的行。

这是我到目前为止所得到的:

travels = Location.objects.filter(pk__in=Location.objects.order_by().values('person_id').annotate(max_id=Max('id')).values('max_id')).order_by('travel_distance')[::-1]

虽然结果相互匹配。第二种方法返回结果需要更长的时间。

无论如何我可以重写这个查询,所以它会变得更快吗?

2 个答案:

答案 0 :(得分:1)

如果我理解正确,你想要每个人的最大行程距离。假设有一个Person模型,也许从另一个方向询问。类似的东西:

Person.objects.values('id').annotate(max_distance=Max('location__travel_distance'))

我没有测试过这个,因为我没有方便的数据模式,但这对你有用吗?

答案 1 :(得分:0)

这不行吗?类似的东西:

select max(id), sum(travel_distance) from table group by person_id;