Rumah >pangkalan data >tutorial mysql >Bagaimanakah Penyertaan Sendiri Boleh Membantu Saya Mencari Perhubungan dalam Jadual Pangkalan Data Tunggal?
Memahami Penyertaan Diri dalam Pangkalan Data
Sertai sendiri ialah teknik pangkalan data yang berkuasa di mana jadual bercantum dengan dirinya sendiri. Ini mengelakkan lebihan data yang sering dikaitkan dengan mencipta jadual pendua, prinsip utama dalam penormalan pangkalan data.
Konsep Gabungan Diri
Bayangkan emp
jadual dengan lajur Name
dan Boss_id
. Untuk mencari nama bos setiap pekerja, anda mungkin secara naluri membuat jadual kedua. Walau bagaimanapun, penyambungan diri secara elegan menyelesaikan masalah ini dalam satu jadual emp
.
Contoh Penyertaan Diri Praktikal
Jom gunakan data sampel ini:
<code>Table: emp Id Name Boss_id 1 ABC 3 2 DEF 1 3 XYZ 2</code>
Untuk mendapatkan semula nama bos bagi setiap pekerja, kami menggunakan penyertaan sendiri:
<code class="language-sql">SELECT e1.Name, e2.Name AS Boss FROM emp e1 INNER JOIN emp e2 ON e1.Boss_id = e2.Id;</code>
Hasil Pertanyaan
Dataset data yang terhasil ialah:
<code>Name Boss ABC XYZ DEF ABC XYZ DEF</code>
Ini jelas menunjukkan hubungan bos-pekerja: bos ABC ialah XYZ, bos DEF ialah ABC, dan bos XYZ ialah DEF.
Aplikasi Penyertaan Diri
Penyertaan diri adalah serba boleh dan boleh digunakan dalam banyak situasi, termasuk:
Atas ialah kandungan terperinci Bagaimanakah Penyertaan Sendiri Boleh Membantu Saya Mencari Perhubungan dalam Jadual Pangkalan Data Tunggal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!