>데이터 베이스 >MySQL 튜토리얼 >LEFT JOIN을 사용하여 Django에서 할당되지 않은 부서를 찾는 방법은 무엇입니까?

LEFT JOIN을 사용하여 Django에서 할당되지 않은 부서를 찾는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-29 09:30:11586검색

How to Find Unassigned Departments in Django Using LEFT JOIN?

Django ORM을 사용하여 할당되지 않은 부서 검색: LEFT JOIN

Django에서는 LEFT JOIN 작업을 우아하게 실행하여 특정 데이터를 검색할 수 있습니다. 이 기술을 사용하여 할당된 자원 봉사자가 없는 부서를 식별하는 방법을 살펴보겠습니다.

Django ORM을 사용한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.