PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Como escrever subconsulta na cláusula From no django ORM


Na verdade, não é possível usar uma Window consulta dentro de um WHERE cláusula. Então, em vez disso, use uma 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')