我正在尝试将这个简单的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]
虽然结果相互匹配。第二种方法返回结果需要更长的时间。
无论如何我可以重写这个查询,所以它会变得更快吗?
答案 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;