Heim >Datenbank >MySQL-Tutorial >Wie kann man mit Djangos ORM effizient Abteilungen ohne Freiwillige finden?

Wie kann man mit Djangos ORM effizient Abteilungen ohne Freiwillige finden?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-30 16:11:12497Durchsuche

How to Efficiently Find Departments Without Volunteers Using Django's ORM?

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:

  1. Verwenden Sie die filter()-Methode, um anzugeben Bedingung.
  2. Verwenden Sie die Methode „values_list()“, um die gewünschten Spaltenwerte abzurufen.

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn