PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

So schreiben Sie eine Unterabfrage in die From-Klausel in Django ORM

Tatsächlich ist es nicht möglich, ein Window zu verwenden Abfrage innerhalb eines WHERE Klausel. Verwenden Sie stattdessen eine 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')