Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan Kembali Semua Subdirektori Direktori Tertentu dalam MySQL Dengan Cekap Menggunakan Pertanyaan Rekursif?

Bagaimana untuk Mendapatkan Kembali Semua Subdirektori Direktori Tertentu dalam MySQL Dengan Cekap Menggunakan Pertanyaan Rekursif?

Susan Sarandon
Lepaskan: 2025-01-03 22:28:44
asal
778 orang telah melayarinya

How to Efficiently Retrieve All Subdirectories of a Specific Directory in MySQL Using Recursive Queries?

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
Salin selepas log masuk

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
Salin selepas log masuk

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;
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan