Mencari Ibu Bapa dalam Jadual MySQL dengan Rekursi
Dalam skema pangkalan data, mewujudkan perhubungan hierarki adalah perkara biasa. Apabila menanyakan data sedemikian, ia menjadi perlu untuk mendapatkan bukan sahaja rekod tertentu tetapi juga sambungan hierarkinya. Artikel ini akan menangani tugas mencari semua ibu bapa rekod dalam jadual MySQL menggunakan satu pertanyaan.
Pernyataan Masalah
Diberikan jadual dengan ID lajur, TITLE , CONTROLLER, METHOD dan PARENT_ID, cari semua ibu bapa rekod dengan TITLE ialah "Kategori" menggunakan satu SQL pertanyaan.
Output yang Diingini
Output hendaklah memaparkan perkara berikut lajur:
dan harus mengambilnya rekod:
id | title | controller | method | url | parent_id |
---|---|---|---|---|---|
3 | Modules | admin | modules | (NULL) | 0 |
17 | User Modules | modules | user_module | (NULL) | 3 |
31 | Categories | categories | category | (NULL) | 17 |
Penyelesaian
Untuk mencapai output yang diingini, kita perlu memanfaatkan keupayaan pertanyaan rekursif MySQL. Berikut ialah pertanyaan SQL yang boleh kita gunakan:
SELECT T2.id, T2.title,T2.controller,T2.method,T2.url FROM ( SELECT @r AS _id, (SELECT @r := parent_id FROM menu WHERE id = _id) AS parent_id, @l := @l + 1 AS lvl FROM (SELECT @r := 31, @l := 0) vars, menu m WHERE @r <> 0) T1 JOIN menu T2 ON T1._id = T2.id ORDER BY T1.lvl DESC;
Mari kita pecahkan pertanyaan ini:
Dengan melaksanakan pertanyaan ini, kami boleh mendapatkan semula semua ibu bapa rekod dengan TITLE sebagai "Kategori" dalam satu pangkalan data panggil.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Cari Semua Rekod Induk dalam Jadual MySQL Menggunakan Pertanyaan Rekursif Tunggal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!