Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Membuat Pertanyaan dengan Cekap untuk Jabatan Tanpa Sukarelawan Ditugaskan Menggunakan Django ORM Left Joins?

Bagaimanakah Saya Boleh Membuat Pertanyaan dengan Cekap untuk Jabatan Tanpa Sukarelawan Ditugaskan Menggunakan Django ORM Left Joins?

Linda Hamilton
Lepaskan: 2024-12-28 06:26:11
asal
760 orang telah melayarinya

How Can I Efficiently Query for Departments Without Assigned Volunteers Using Django ORM Left Joins?

Menyertai Kiri dalam ORM Django

Apabila berurusan dengan perhubungan pangkalan data yang kompleks, situasi mungkin timbul di mana anda perlu menanyakan data sambil mengambil kira kehadiran atau ketiadaan rekod berkaitan. Satu teknik untuk berbuat demikian dikenali sebagai penyertaan kiri.

Andaikan anda mempunyai model berikut:

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)
Salin selepas log masuk

Anda ingin bertanya untuk semua jabatan yang tidak mempunyai sebarang sukarelawan yang ditugaskan untuk mereka . Pertanyaan SQL mentah berikut akan mencapai ini:

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;
Salin selepas log masuk

Dalam Django, anda boleh melakukan operasi gabungan kiri dengan mengikuti hubungan ke belakang dalam carian. Berikut ialah persamaan Django bagi pertanyaan SQL mentah di atas:

qs = Department.objects.filter(
    departmentvolunteer__isnull=True).values_list('name', flat=True)
Salin selepas log masuk

Pertanyaan yang dijana akan hampir sama dengan pertanyaan SQL mentah, seperti ditunjukkan di bawah:

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
Salin selepas log masuk

Kaedah ini membolehkan anda untuk menanyakan data dengan cekap sambil memanfaatkan kuasa ORM Django, menyediakan pendekatan yang lebih Pythonic dan boleh diselenggara berbanding dengan mentah SQL.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membuat Pertanyaan dengan Cekap untuk Jabatan Tanpa Sukarelawan Ditugaskan Menggunakan Django ORM Left Joins?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan