Dalam pangkalan data Oracle, menanyakan nod anak nod adalah keperluan biasa, terutamanya apabila berurusan dengan data hierarki yang besar. Dalam artikel ini, kami akan memperkenalkan cara menggunakan pernyataan CONNECT BY Oracle dan fungsi SYS_CONNECT_BY_PATH untuk menanyakan nod anak.
Pertama, mari kita lihat kenyataan CONNECT BY. Pernyataan CONNECT BY ialah pernyataan pertanyaan rekursif Oracle, yang membenarkan pertanyaan struktur pepohon atau data hierarki. Terdapat dua cara untuk menggunakan CONNECT BY: satu ialah menggunakan klausa START WITH untuk menentukan nod permulaan pertanyaan, dan satu lagi ialah meninggalkan MULA DENGAN, dalam hal ini pertanyaan rekursif akan dilakukan daripada keseluruhan jadual.
Mari berikan contoh mudah untuk menggambarkan kaedah pertanyaan ini. Katakan kita mempunyai jadual bernama "PEKERJA", yang mengandungi maklumat pekerja Terdapat medan "DEPT_ID" yang mewakili jabatan di mana pekerja berada dan medan "EMP_ID" mewakili ID unik pekerja.
Kami boleh menyoal semua pekerja yang "DEPT_ID" mereka ialah 100 melalui penyataan berikut:
SELECT * FROM EMPLOYEE START WITH DEPT_ID = 100 CONNECT BY PRIOR EMP_ID = MANAGER_ID;
Pernyataan pertanyaan ini bermaksud menanyakan pekerja mereka secara rekursif bermula daripada pekerja yang "DEPT_ID"nya ialah 100 . Pekerja bawahan, dengan "PRIOR" ialah kata kunci yang menunjukkan pekerja rekursif peringkat atas dan "MANAGER_ID" ialah medan yang menunjukkan ID pengurus peringkat atasan pekerja.
Dalam hasil pertanyaan, kita dapat melihat maklumat semua pekerja yang mempunyai "DEPT_ID" 100 dan pekerja bawahannya.
Bagaimanapun, kaedah ini tidak memberikan maklumat tahap setiap pekerja, iaitu tahap lapisan setiap pekerja. Pada masa ini, kita perlu menggunakan fungsi SYS_CONNECT_BY_PATH untuk mendapatkan laluan penuh setiap nod.
Berikut ialah contoh:
SELECT EMPLOYEE.*, LEVEL, SYS_CONNECT_BY_PATH(EMP_ID, '/') AS PATH FROM EMPLOYEE START WITH DEPT_ID = 100 CONNECT BY PRIOR EMP_ID = MANAGER_ID;
Dalam hasil pertanyaan, kita boleh melihat maklumat laluan lengkap setiap pekerja, seperti "/100/101/103". Di sini, "/" ialah pemisah laluan, dan "LEVEL" ialah pembolehubah sistem yang menunjukkan tahap lapisan nod semasa.
Selain itu, kami juga boleh menggunakan kaedah lain untuk menanyakan nod anak. Sebagai contoh, kita boleh menggunakan kata kunci "WITH" untuk mencipta ungkapan awam dan menggunakannya dalam pertanyaan. Kaedah ini lebih mudah dibaca dan memudahkan untuk menggabungkan syarat pertanyaan.
Ringkasnya, anda boleh menggunakan penyataan CONNECT BY dan fungsi SYS_CONNECT_BY_PATH untuk menanyakan nod anak nod dalam pangkalan data Oracle. Dalam aplikasi praktikal, kaedah pertanyaan yang berbeza boleh dipilih mengikut keperluan khusus untuk mencapai hasil yang lebih baik.
Atas ialah kandungan terperinci Bagaimana untuk menanyakan nod anak dalam oracle. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!