LEFT JOIN Django ORM

Habe ich die folgenden Modelle:

class Volunteer(models.Model):
    first_name = models.CharField(max_length=50L)
    last_name = models.CharField(max_length=50L)    
    email = models.CharField(max_length=50L)
    gender = models.CharField(max_length=1, choices=GENDER_CHOICES)


class Department(models.Model):
    name = models.CharField(max_length=50L, unique=True)
    overseer = models.ForeignKey(Volunteer, blank=True, null=True)
    location = models.CharField(max_length=100L, null=True)


class DepartmentVolunteer(models.Model):
    volunteer = models.ForeignKey(Volunteer)
    department = models.ForeignKey(Department)
    assistant = models.BooleanField(default=False)
    keyman = models.BooleanField(default=False)
    captain = models.BooleanField(default=False)
    location = models.CharField(max_length=100L, blank=True, null=True)

Ich möchte die Abfrage für alle Abteilungen, die keine Freiwilligen zugewiesen. Ich kann so tun, mithilfe der folgenden Abfrage:

SELECT 
    vsp_department.name 
FROM   
    vsp_department 
LEFT JOIN vsp_departmentvolunteer ON vsp_department.id = vsp_departmentvolunteer.department_id  
WHERE
    vsp_departmentvolunteer.department_id IS NULL;

Gibt es eine weitere django-ähnliche Art und Weise, dies zu tun, oder sollte ich gehen Sie einfach mit raw-sql?

InformationsquelleAutor hanleyhansen | 2014-01-22

Schreibe einen Kommentar