PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Come scrivere una sottoquery nella clausola From in django ORM

In effetti, non è possibile utilizzare una Window query all'interno di un WHERE clausola. Quindi, invece, usa una 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')