Heim >Datenbank >MySQL-Tutorial >Wie kann man mit Djangos ORM effizient Abteilungen ohne Freiwillige finden?
LEFT JOIN in Django ORM
Die Left-Join-Operation wird häufig verwendet, um Daten aus mehreren Tabellen abzurufen, indem Zeilen mit passenden Spalten kombiniert werden. In Django können Sie dies mit den Methoden filter() und Values_list() erreichen.
Stellen Sie sich das folgende Szenario vor: Sie haben drei Modelle – Volunteer, Department und DepartmentVolunteer. Ein Freiwilliger kann mehreren Abteilungen angehören und eine Abteilung kann mehrere Freiwillige haben. Sie möchten alle Abteilungen abrufen, denen keine Freiwilligen zugewiesen sind.
Eine Möglichkeit, dies zu erreichen, ist eine Roh-SQL-Abfrage:
SELECT d.name FROM vsp_department AS d LEFT JOIN vsp_departmentvolunteer AS dv ON d.id = dv.department_id WHERE dv.department_id IS NULL;
Django bietet jedoch eine elegantere und elegantere Lösung Pythonische Möglichkeit, diesen Vorgang mit den folgenden Schritten auszuführen:
Der folgende Code veranschaulicht diesen Ansatz:
qs = Department.objects.filter( departmentvolunteer__isnull=True).values_list('name', flat=True) print(qs.query)
Diese Abfrage generiert die Folgende SQL:
SELECT "app_department"."name" FROM "app_department" LEFT OUTER JOIN "app_departmentvolunteer" ON ( "app_department"."id" = "app_departmentvolunteer"."department_id" ) WHERE "app_departmentvolunteer"."id" IS NULL
gibt die Namen von Abteilungen zurück, denen keine Freiwilligen zugewiesen sind.
Das obige ist der detaillierte Inhalt vonWie kann man mit Djangos ORM effizient Abteilungen ohne Freiwillige finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!