SERTAI DALAM dan SERTAI LUAR: Memahami Interaksi mereka
Artikel ini meneroka cara menggabungkan INNER JOIN dan OUTER JOIN (KIRI, KANAN atau PENUH) dalam pertanyaan SQL boleh menjejaskan set hasil akhir. Secara khusus, kami akan memeriksa sama ada JOIN DALAM yang berikutnya boleh mengatasi gelagat OUTER JOIN sebelumnya.
Kesan Sertai Pesanan
Kuncinya terletak pada klausa ON
setiap gabungan. JOIN DALAM kemudian hanya akan menafikan kesan OUTER JOIN yang lebih awal jika fasal ON
nya memerlukan nilai bukan nol daripada lajur yang mungkin NULL disebabkan OUTER JOIN. Hanya menukar pesanan penyertaan tidak akan membetulkan perkara ini; sebaliknya, JOIN DALAM perlu ditukar kepada OUTER JOIN yang lebih sesuai.
Contoh Ilustrasi
Pertimbangkan senario ini:
Pertanyaan ini berfungsi seperti yang dijangkakan:
<code class="language-sql">SELECT * FROM person LEFT JOIN address ON person.address_id = address.id INNER JOIN email ON person.email_id = email.id</code>
Hasilnya adalah sama jika LEFT JOIN
diletakkan selepas INNER JOIN
.
Walau bagaimanapun, pertanyaan ini berkelakuan berbeza:
<code class="language-sql">SELECT * FROM person LEFT JOIN address ON person.address_id = address.id INNER JOIN city ON address.city_id = city.id</code>
Di sini, INNER JOIN
pada city
gagal untuk mana-mana person
tanpa entri address
yang sepadan, kerana address.city_id
boleh jadi NULL. Penyelesaiannya ialah menggantikan INNER JOIN
dengan LEFT JOIN
.
Amalan Disyorkan untuk Kebolehbacaan dan Kecekapan
Untuk kebolehbacaan dan kebolehselenggaraan kod yang dipertingkatkan, adalah amalan terbaik untuk memesan penyertaan anda secara logik. Letakkan INNER JOIN terlebih dahulu, kerana ia mewakili hubungan teras, diikuti oleh OUTER JOIN. Walaupun PENYERTAAN LUAR KANAN adalah kurang biasa, secara amnya dinasihatkan untuk mengelak daripada menyertai KIRI OUTER JOIN untuk konsistensi. Pendekatan ini jelas menggambarkan perhubungan data penting dan sambungan pilihan yang diperkenalkan oleh OUTER JOINs.
Atas ialah kandungan terperinci Bolehkah JOIN DALAM Mengatasi Keputusan JOIN OUTER?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!