집 >데이터 베이스 >MySQL 튜토리얼 >LEFT JOIN을 사용하여 Django에서 할당되지 않은 부서를 찾는 방법은 무엇입니까?
Django에서는 LEFT JOIN 작업을 우아하게 실행하여 특정 데이터를 검색할 수 있습니다. 이 기술을 사용하여 할당된 자원 봉사자가 없는 부서를 식별하는 방법을 살펴보겠습니다.
다음 모델이 주어지면:
class Volunteer(models.Model): first_name = models.CharField(max_length=50) last_name = models.CharField(max_length=50) email = models.CharField(max_length=50) gender = models.CharField(max_length=1, choices=GENDER_CHOICES) class Department(models.Model): name = models.CharField(max_length=50, unique=True) overseer = models.ForeignKey(Volunteer, blank=True, null=True) location = models.CharField(max_length=100, 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=100, blank=True, null=True)
Django ORM을 활용할 수 있습니다. 관련이 없는 부서를 얻으려면 LEFT JOIN 자원 봉사자:
qs = Department.objects.filter(departmentvolunteer__isnull=True).values_list('name', flat=True)
생성된 쿼리는 다음과 같습니다.
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
이 쿼리는 DepartmentVolunteer 테이블에 항목이 없는 부서 이름을 검색합니다. .
Django ORM은 필터링을 통해 "다중 값 관계 확장"을 지원하므로 복잡한 관계를 효율적으로 탐색할 수 있습니다.
이 주제에 대한 문서는 여기에서 찾을 수 있습니다: https:/ /docs.djangoproject.com/en/stable/topics/db/queries/#spanning-multi-valued-relationships
위 내용은 LEFT JOIN을 사용하여 Django에서 할당되지 않은 부서를 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!