Thật vậy, không thể sử dụng Window
truy vấn bên trong WHERE
mệnh đề. Vì vậy, thay vào đó, hãy sử dụng Subquery
:
from django.db.models import OuterRef, Subquery
top_salaries = EmpSalary.objects.filter(
depname=OuterRef('depname')
).order_by('-salary')[:3]
result = EmpSalary.objects.filter(
pk__in=Subquery(top_salaries.values('pk'))
).values('depname', 'empno', 'salary', 'enroll_date')