Artikel ini membawakan anda pengetahuan yang berkaitan tentang Oracle, yang terutamanya memperkenalkan kandungan yang berkaitan tentang pelan pelaksanaan pertanyaan Pelan pelaksanaan juga dipanggil pelan pertanyaan, yang merupakan langkah khusus untuk pangkalan data untuk dilaksanakan Penyataan SQL. Mari kita lihat proses di bawah saya harap ia akan membantu semua orang.
Tutorial yang disyorkan: "Tutorial Video Oracle"
Pelan Pelaksanaan juga dipanggil Pelan Pertanyaan Ia adalah langkah dan proses khusus untuk pangkalan data melaksanakan pernyataan SQL. Pelan pelaksanaan pernyataan pertanyaan SQL terutamanya termasuk:
Cara untuk mengakses jadual. Pangkalan data mengakses data dalam jadual melalui indeks atau imbasan jadual penuh.
Kaedah sambungan berbilang jadual. Algoritma sambungan yang digunakan oleh pangkalan data untuk menyambungkan jadual, termasuk jujukan capaian berurutan bagi berbilang jadual.
Cara melaksanakan operasi seperti pengumpulan, pengagregatan dan pengisihan.
Walaupun pangkalan data yang berbeza menggunakan kaedah pelaksanaan yang berbeza untuk proses pelaksanaan pertanyaan SQL, pernyataan pertanyaan secara amnya perlu diproses oleh penganalisis, pengoptimum dan pelaksana dan mengembalikan hasil akhir masa yang sama, pelbagai cache juga boleh digunakan untuk meningkatkan prestasi capaian.
Ringkasnya, pernyataan pertanyaan bermula dari penyerahan klien sehingga pelayan mengembalikan hasil akhir Keseluruhan proses adalah secara kasar seperti yang ditunjukkan dalam rajah.
Pertama, pelanggan menyerahkan pernyataan SQL. Sebelum ini, pelanggan mesti menyambung ke pelayan pangkalan data Penyambung dalam rajah adalah komponen yang bertanggungjawab untuk mewujudkan dan menguruskan sambungan pelanggan.
Kemudian, penganalisis (penghurai) menghuraikan pelbagai komponen pernyataan SQL, menjalankan analisis sintaks dan menyemak sama ada sintaks pernyataan SQL mematuhi spesifikasi.
Sebagai contoh, kata kunci FROM dalam pernyataan berikut salah ditulis sebagai FORM:
Dalam kes ini, semua sistem pengurusan pangkalan data akan mengembalikan kesilapan sintaks .
Pengoptimum kemudian menggunakan maklumat statistik yang dikumpul oleh pangkalan data untuk menentukan cara terbaik untuk melaksanakan pernyataan SQL. Contohnya, sama ada untuk mengakses satu jadual melalui indeks atau imbasan jadual penuh, susunan yang hendak digunakan untuk menyambung berbilang jadual, cara mengisih data, dsb.
Pengoptimum ialah komponen utama yang menentukan prestasi pertanyaan dan maklumat statistik pangkalan data adalah asas untuk pertimbangan pengoptimum.
Akhir sekali, pelaksana memanggil modul pelaksanaan yang sepadan untuk mendapatkan data mengikut pelan pelaksanaan yang dioptimumkan, dan mengembalikan hasilnya kepada pelanggan.
Dalam pangkalan data Oracle, kita juga boleh menggunakan EXPLAIN The Perintah PLAN FOR menjana pelan pelaksanaan, tetapi dua arahan perlu dilaksanakan:
EXPLAIN PLAN FOR SELECT * FROM T_USER1 t where t.user_name = 'Admin'; SELECT * FROM TABLE(dbms_xplan.display);
Gunakan arahan EXPLAIN PLAN FOR untuk menjana pelan pelaksanaan dan simpannya dalam jadual sistem PLAN_TABLE , dan kemudian paparkan pelan pelaksanaan yang dijana melalui pernyataan pertanyaan.
Di mana dbms_xplan.display ialah fungsi sistem Oracle. Keputusan yang dikembalikan menunjukkan bahawa pernyataan mencari data melalui imbasan julat indeks 'SYS_C0016771' dalam Oracle.
Dalam alat pembangunan pangkalan data Oracle PL/SQL yang biasa digunakan, pilih skrip SQL , Tekan kekunci F5 untuk memaparkan secara automatik maklumat pelan pelaksanaan skrip, yang sama dengan keputusan yang ditanya dalam kaedah 1.
Rujuk artikel berikut:
Dalam pangkalan data Oracle, kita boleh menggunakan jadual sistem indeks pertanyaan pengguna dan lajur_pengguna dan maklumat medan yang berkaitan.
SELECT * FROM user_indexes; SELECT * FROM user_ind_columns;
Tutorial yang disyorkan: "Tutorial Video Oracle"
Atas ialah kandungan terperinci Mari kita bincangkan tentang cara Oracle menanyakan rancangan pelaksanaan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!