Pertanyaan Rekursif untuk Struktur Folder Bersarang dalam MySQL
Pertimbangkan senario dengan jadual yang menyimpan struktur folder hierarki, di mana setiap folder mempunyai ID , ID folder induk dan nama. Jadual ini direka bentuk seperti berikut:
folders_table ----------------------- id_folder id_folder_parent folder_name
Cabarannya ialah untuk mendapatkan semula semua subdirektori direktori tertentu menggunakan pertanyaan SELECT tunggal.
Penyelesaian: Mengkaji Struktur Pangkalan Data
Satu pendekatan melibatkan pengubahsuaian struktur pangkalan data untuk memudahkan pertanyaan rekursif. Daripada menyimpan perhubungan tidak langsung melalui lajur id_folder_parent, pertimbangkan untuk menggunakan struktur berikut:
folders_table ----------------------- id_folder folder_path folder_name
Dalam struktur yang dikemas kini ini, lajur folder_path menyimpan laluan lengkap setiap folder dalam hierarki, bermula dari direktori akar. Ini membolehkan traversal yang cekap melalui struktur folder menggunakan rekursi.
Pertanyaan Rekursif
Setelah struktur pangkalan data diubah suai, pertanyaan rekursif berikut boleh digunakan untuk mendapatkan semula semua subdirektori daripada direktori tertentu:
WITH RECURSIVE FolderTraversal AS ( SELECT id_folder, folder_path, folder_name FROM folders_table WHERE id_folder = <directory_id> UNION ALL SELECT t.id_folder, t.folder_path, t.folder_name FROM folders_table AS t JOIN FolderTraversal AS p ON t.folder_path LIKE CONCAT(p.folder_path, '%/') ) SELECT id_folder, folder_path, folder_name FROM FolderTraversal;
Dalam pertanyaan di atas, lajur folder_path digunakan untuk menentukan rekursi. Ia secara berulang menambahkan laluan folder semasa ke laluan folder seterusnya, menyambungkan cawangan pokok. Dengan memulakan pertanyaan pada directory_id yang ditentukan, ia merentasi keseluruhan subpokok secara rekursif.
Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Kembali Semua Subdirektori Direktori Tertentu dalam MySQL Dengan Cekap Menggunakan Pertanyaan Rekursif?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!