Django QuerySet过滤器+ order_by + limit

时间:2010-06-15 17:36:02

标签: python django django-queryset django-orm

所以我有一个处理测试结果的Django应用程序,我试图找到某个评估的中位数分数。我认为这会奏效:

e = Exam.objects.all()
total = e.count()
median = int(round(total / 2))
median_exam = Exam.objects.filter(assessment=assessment.id).order_by('score')[median:1]
median_score = median_exam.score

但它总是返回一个空列表。我可以用这个得到我想要的结果:

e = Exam.objects.all()
total = e.count()
median = int(round(total / 2))
exams = Exam.objects.filter(assessment=assessment.id).order_by('score')
median_score = median_exam[median].score

我只是不想查询整套考试。我想过只编写一个原始MySQL查询,看起来像:

SELECT score FROM assess_exam WHERE assessment_id = 5 ORDER BY score LIMIT 690,1

但如果可能的话,我想留在Django的ORM中。大多数情况下,我只是在困扰我,似乎无法使用带有过滤器和限制的order_by。有什么想法吗?

1 个答案:

答案 0 :(得分:5)

您的切片语法错误。冒号后面的值不是要获取的元素数,而是切片结尾的索引。

,就像你在第二个例子中所做的那样,在没有冒号的情况下单独使用“中位数”