PL/SQL ialah bahasa pengaturcaraan pangkalan data Oracle dan boleh digunakan untuk mencipta prosedur tersimpan, pencetus, fungsi, pakej, dsb. Artikel ini akan memperkenalkan cara Oracle menggunakan PL/SQL.
1. Buat prosedur tersimpan
Prosedur tersimpan ialah satu set pernyataan SQL Prosedur tersimpan boleh dianggap sebagai fungsi tersuai. Menggunakan prosedur tersimpan boleh memudahkan pertanyaan SQL yang kompleks dan meningkatkan prestasi pangkalan data.
Dalam Oracle, sintaks untuk mencipta prosedur tersimpan adalah seperti berikut:
CREATE OR REPLACE PROCEDURE procedure_name (parameter1 datatype, parameter2 datatype,....) IS BEGIN statement1; statement2; ... END; /
di mana CREATE OR REPLACE PROCEDURE mewakili mencipta atau menggantikan prosedur tersimpan, procedure_name mewakili nama prosedur tersimpan , dan parameter1 dan parameter2 ialah input Parameter, datatype menunjukkan jenis data parameter. Antara IS dan BEGIN ialah bahagian utama prosedur tersimpan, yang mengandungi satu siri pernyataan SQL. TAMAT menunjukkan tamat prosedur yang disimpan.
Berikut ialah contoh prosedur tersimpan mudah untuk mengira hasil tambah dua nombor:
CREATE OR REPLACE PROCEDURE addition (num1 IN NUMBER, num2 IN NUMBER, sum OUT NUMBER) IS BEGIN sum := num1 + num2; END; /
Dalam contoh di atas, penambahan ialah nama prosedur tersimpan, dan num1 dan num2 ialah dua Terdapat parameter input, dan jumlah ialah parameter output. Di bahagian utama prosedur tersimpan, gunakan jumlah := num1 + num2 untuk mengira jumlah dua nombor dan menetapkan hasilnya kepada jumlah parameter output.
2. Cipta pencetus
Pencetus ialah program yang dilaksanakan secara automatik dalam pangkalan data dan boleh digunakan apabila pelbagai operasi dalam pangkalan data (seperti memasukkan, mengemas kini atau memadam data) berlaku. Pencetus sering digunakan untuk pengauditan dan pengelogan data.
Dalam Oracle, sintaks untuk mencipta trigger adalah seperti berikut:
CREATE OR REPLACE TRIGGER trigger_name BEFORE/AFTER INSERT/UPDATE/DELETE ON table_name FOR EACH ROW BEGIN statement1; statement2; ... END; /
Antaranya, CREATE OR REPLACE TRIGGER bermaksud mencipta atau menggantikan trigger, trigger_name bermaksud nama pencetus, dan SEBELUM/SELEPAS bermaksud pemasaan Pencetus, INSERT/KEMASKINI/DELETE menunjukkan operasi aksara pencetus, table_name menunjukkan jadual yang sepadan dengan pencetus, dan UNTUK SETIAP BARIS menunjukkan bahawa pernyataan dalam pencetus dilaksanakan untuk setiap baris data.
Berikut ialah contoh pencetus mudah untuk merekodkan masa sisipan apabila data dimasukkan:
CREATE OR REPLACE TRIGGER insert_time BEFORE INSERT ON customer FOR EACH ROW BEGIN :new.created_at := sysdate; END; /
Dalam contoh di atas, insert_time ialah nama pencetus dan SEBELUM INSERT bermaksud dalam Laksanakan pencetus sebelum memasukkan data, pelanggan ialah nama jadual yang sepadan dengan pencetus. Di bahagian utama pencetus, gunakan: new.created_at := sysdate;
3. Cipta fungsi
Fungsi ialah unit program PL/SQL dengan nilai pulangan yang boleh menerima sifar atau lebih parameter sebagai input dan mengembalikan nilai sebagai output. Menggunakan fungsi boleh merangkum sekeping logik, menjadikan kod lebih mudah dibaca dan diselenggara.
Dalam Oracle, sintaks untuk mencipta fungsi adalah seperti berikut:
CREATE OR REPLACE FUNCTION function_name (return_type IN OUT datatype, parameter1 datatype, parameter2 datatype,....) RETURN return_datatype IS BEGIN statement1; statement2; ... RETURN return_value; END; /
Antaranya, BUAT ATAU GANTIKAN FUNGSI bermaksud mencipta atau menggantikan fungsi, nama_fungsi bermaksud nama fungsi, return_type bermaksud jenis nilai pulangan, parameter1 dan parameter2 ialah parameter input, datatype menunjukkan jenis data parameter, dan RETURN return_datatype menunjukkan jenis data nilai pulangan. Dalam badan fungsi, gunakan pernyataan RETURN return_value untuk mengembalikan hasil pengiraan kepada pemanggil.
Berikut ialah contoh mudah fungsi yang mengira hasil darab dua nombor:
CREATE OR REPLACE FUNCTION multiplication(x IN NUMBER, y IN NUMBER) RETURN NUMBER IS BEGIN RETURN x * y; END; /
Dalam contoh di atas, pendaraban ialah nama fungsi dan x dan y ialah dua input Parameter, RETURN NUMBER bermakna jenis data bagi nilai pulangan ialah NOMBOR, dan nilai pulangan ialah hasil x*y.
4. Cipta pakej
Pakej ialah modul program yang menyimpan set unit program PL/SQL Ia boleh merangkum unit program yang berkaitan seperti fungsi, prosedur tersimpan, pembolehubah dan pemalar ke Dalam satu pakej. Menggunakan pakej boleh menjadikan program anda lebih mudah dibaca dan diselenggara.
Dalam Oracle, sintaks untuk mencipta pakej adalah seperti berikut:
CREATE OR REPLACE PACKAGE package_name IS /* 声明变量、常量和异常 */ ... /* 声明存储过程和函数 */ PROCEDURE procedure_name; FUNCTION function_name RETURN NUMBER; END; / CREATE OR REPLACE PACKAGE BODY package_name IS /* 实现存储过程和函数 */ PROCEDURE procedure_name IS BEGIN /* 存储过程的逻辑处理 */ END; FUNCTION function_name RETURN NUMBER IS BEGIN /* 函数的逻辑处理 */ RETURN 0; END; END; /
Antaranya, BUAT ATAU GANTIKAN PAKEJ mewakili mencipta atau menggantikan pakej, package_name mewakili nama pakej, dan IS mewakili bahagian pengisytiharan pakej TAMAT mewakili penghujung pakej, CIPTA ATAU GANTIKAN BADAN PAKEJ mewakili mencipta atau menggantikan badan pakej, dan nama pakej mewakili nama pakej.
Di atas adalah pengenalan ringkas tentang cara Oracle menggunakan PL/SQL Melalui PL/SQL, anda boleh mencipta unit program seperti prosedur tersimpan, pencetus, fungsi dan pakej untuk melaksanakan operasi pangkalan data dan pemprosesan logik.
Atas ialah kandungan terperinci Bagaimana Oracle menggunakan PL/SQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!