SQL Server: INNER JOIN lwn. LEFT JOIN Prestasi – Penyelaman Lebih Dalam
Salah tanggapan biasa dalam SQL Server ialah LEFT JOIN
sentiasa mengatasi INNER JOIN
. Ini tidak semestinya benar. Jenis gabungan optimum banyak bergantung pada pertanyaan khusus dan ciri data. Mari kita periksa perbezaannya.
An INNER JOIN
hanya mengembalikan baris yang sepadan daripada semua jadual yang digabungkan. A LEFT JOIN
mengembalikan semua baris dari jadual kiri dan baris yang sepadan dari jadual kanan. Jika tiada padanan di sebelah kanan, nilai NULL
mengisi lajur yang sepadan.
Contoh pertanyaan, yang melibatkan sembilan jadual yang digabungkan menggunakan INNER JOIN
, berkemungkinan mengalami masalah prestasi disebabkan oleh imbasan jadual yang banyak diperlukan. Beralih kepada LEFT JOIN
dalam sesetengah keadaan mungkin meningkatkan prestasi dengan mengurangkan bilangan imbasan, kerana ia tidak menapis baris yang tiada padanan dalam jadual berikutnya.
Walau bagaimanapun, LEFT JOIN
tidak semestinya lebih pantas. Ia selalunya menggunakan lebih banyak sumber untuk mengendalikan kemasukan baris yang tidak sepadan. Secara amnya, INNER JOIN
diutamakan untuk padanan tepat, manakala LEFT JOIN
lebih sesuai apabila anda memerlukan semua baris dari jadual kiri, tanpa mengira padanan meja kanan.
Mengoptimumkan Prestasi Pertanyaan:
Untuk meningkatkan prestasi, fokus pada bidang utama ini:
Pengindeksan: Skema yang disediakan menyerlahkan isu penting: jadual a
dan b
kekurangan kunci utama atau asing. Ini dengan ketara menghalang carian baris yang cekap. Menambah indeks pada lajur yang terlibat dalam syarat penyertaan (cth., CompanyCd
, SPRNo
, SuffixNo
, dnno
, ProductSalesCd
, dsb.) akan meningkatkan prestasi secara drastik, walaupun dengan LEFT JOIN
.
Analisis Skema: Semak perhubungan jadual dengan teliti. Gabungan yang tidak perlu meningkatkan overhed pemprosesan. Pastikan penyertaan anda adalah logik dan meminimumkan operasi berlebihan.
Pilihan Jenis Sertai: Pilih jenis gabungan yang menggambarkan keperluan pengambilan data anda dengan tepat. Jangan sewenang-wenangnya menganggap LEFT JOIN
lebih pantas.
Analisis Skema dan Cadangan Pengoptimuman:
Petikan skema yang disediakan:
<code class="language-sql">FROM sidisaleshdrmly a -- NOT HAVE PK AND FK LEFT JOIN sidisalesdetmly b -- THIS TABLE ALSO HAVE NO PK AND FK ON a.CompanyCd = b.CompanyCd AND a.SPRNo = b.SPRNo AND a.SuffixNo = b.SuffixNo AND a.dnno = b.dnno -- ... (rest of the joins)</code>
Dengan jelas menunjukkan keperluan untuk kunci utama dan asing dalam jadual a
dan b
, mewujudkan hubungan yang jelas antara jadual. Menambah kunci ini dan indeks yang sesuai akan meningkatkan prestasi pertanyaan secara mendadak tanpa mengira sama ada anda menggunakan INNER JOIN
atau LEFT JOIN
.
Kesimpulan:
Walaupun LEFT JOIN
kadangkala boleh memberikan manfaat prestasi, adalah penting untuk memahami implikasinya dan menggunakannya dengan sewajarnya. Analisis skema yang teliti, pengindeksan yang betul dan pemilihan jenis gabungan yang teliti adalah penting untuk prestasi pertanyaan SQL Server yang optimum. Jangan bergantung pada andaian; menganalisis keperluan khusus anda dan mengoptimumkan dengan sewajarnya.
Atas ialah kandungan terperinci Bilakah LEFT JOIN lebih disukai daripada INNER JOIN dalam SQL Server, dan mengapa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!