Rumah >pangkalan data >tutorial mysql >Bagaimanakah Penyertaan Sendiri Boleh Membantu Perhubungan Pertanyaan dalam Jadual Pangkalan Data Tunggal?
Sertai Diri: Gambaran Keseluruhan Komprehensif
Dalam pengurusan pangkalan data perhubungan, penyambungan diri ialah teknik yang berkuasa untuk menanyakan data dalam satu jadual. Kaedah ini membolehkan anda menyambungkan baris dalam jadual yang sama, dengan berkesan menganggapnya sebagai dua set data yang berbeza.
Memahami Mekanik Penyatuan Diri
Sertai sendiri amat berguna apabila mewujudkan perhubungan antara lajur atau baris yang tidak ditakrifkan secara eksplisit dalam struktur jadual. Pertimbangkan jadual "Pekerja" dengan ID pekerja, nama dan ID penyelia. Penyertaan sendiri boleh mendapatkan maklumat pekerja dan penyelia dengan mudah.
Contoh Ilustratif Gabungan Diri
Mari kita periksa perkara ini dengan sampel set data:
<code>Table: Employees | Id | Name | Supervisor_id | |---|---|---| | 1 | ABC | 3 | | 2 | DEF | 1 | | 3 | XYZ | 2 |</code>
Untuk memaparkan nama setiap pekerja bersama nama penyelia mereka, kami menggunakan penyertaan sendiri:
<code class="language-sql">SELECT e1.Name AS EmployeeName, e2.Name AS SupervisorName FROM Employees e1 INNER JOIN Employees e2 ON e1.Supervisor_id = e2.Id;</code>
Pertanyaan ini memautkan jadual "Pekerja" kepada dirinya sendiri. e1
mewakili pekerja dan e2
mewakili penyelia mereka. Syarat penyertaan sepadan dengan Supervisor_id
pekerja dengan Id
penyelia.
Jadual Hasil
Keluaran pertanyaan akan menyerupai ini:
<code>| EmployeeName | SupervisorName | |---|---| | ABC | XYZ | | DEF | ABC | | XYZ | DEF |</code>
Ini jelas menunjukkan setiap pekerja dan penyelia mereka yang sepadan.
Penyertaan diri tidak ternilai untuk manipulasi data, memudahkan penciptaan pertanyaan rumit dan mendedahkan cerapan berharga daripada pangkalan data anda.
Atas ialah kandungan terperinci Bagaimanakah Penyertaan Sendiri Boleh Membantu Perhubungan Pertanyaan dalam Jadual Pangkalan Data Tunggal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!