Bagaimana Oracle menggunakan PL/SQL

PHPz
PHPzasal
2023-04-17 10:29:49926semak imbas

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!

Kenyataan:
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