PL / SQL - Prosedur

Pada bab ini, kita akan membahas Prosedur dalam PL / SQL. SEBUAHsubprogramadalah unit / modul program yang menjalankan tugas tertentu. Subprogram ini digabungkan untuk membentuk program yang lebih besar. Ini pada dasarnya disebut 'desain Modular'. Sebuah subprogram dapat dipanggil oleh subprogram atau program lain yang disebutcalling program.

Sebuah subprogram dapat dibuat -

  • Di level skema
  • Di dalam sebuah paket
  • Di dalam blok PL / SQL

Pada level skema, subprogram adalah a standalone subprogram. Itu dibuat dengan pernyataan CREATE PROCEDURE atau CREATE FUNCTION. Itu disimpan dalam database dan dapat dihapus dengan pernyataan DROP PROCEDURE atau DROP FUNCTION.

Subprogram yang dibuat di dalam paket adalah packaged subprogram. Itu disimpan dalam database dan hanya dapat dihapus ketika paket dihapus dengan pernyataan DROP PACKAGE. Kami akan membahas paket di bab ini'PL/SQL - Packages'.

Subprogram PL / SQL diberi nama blok PL / SQL yang dapat dipanggil dengan sekumpulan parameter. PL / SQL menyediakan dua jenis subprogram -

  • Functions- Subprogram ini mengembalikan satu nilai; terutama digunakan untuk menghitung dan mengembalikan nilai.

  • Procedures- Subprogram ini tidak mengembalikan nilai secara langsung; terutama digunakan untuk melakukan suatu tindakan.

Bab ini akan membahas aspek-aspek penting dari a PL/SQL procedure. Kami akan membahasPL/SQL function di bab selanjutnya.

Bagian dari Subprogram PL / SQL

Setiap subprogram PL / SQL memiliki nama, dan mungkin juga memiliki daftar parameter. Seperti blok PL / SQL anonim, blok bernama juga akan memiliki tiga bagian berikut -

S.No Bagian & Deskripsi
1

Declarative Part

Ini adalah bagian opsional. Namun, bagian deklaratif untuk subprogram tidak dimulai dengan kata kunci MENYATAKAN. Ini berisi deklarasi tipe, kursor, konstanta, variabel, pengecualian, dan subprogram bertingkat. Item ini bersifat lokal untuk subprogram dan tidak ada lagi saat subprogram menyelesaikan eksekusi.

2

Executable Part

Ini adalah bagian wajib dan berisi pernyataan yang melakukan tindakan yang ditentukan.

3

Exception-handling

Ini lagi-lagi merupakan bagian opsional. Ini berisi kode yang menangani kesalahan run-time.

Membuat Prosedur

Sebuah prosedur dibuat dengan CREATE OR REPLACE PROCEDUREpernyataan. Sintaks yang disederhanakan untuk pernyataan CREATE OR REPLACE PROCEDURE adalah sebagai berikut -

CREATE [OR REPLACE] PROCEDURE procedure_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
{IS | AS} 
BEGIN 
  < procedure_body > 
END procedure_name;

Dimana,

  • procedure-name menentukan nama prosedur.

  • Opsi [ATAU GANTI] memungkinkan modifikasi dari prosedur yang ada.

  • Daftar parameter opsional berisi nama, mode, dan jenis parameter. IN mewakili nilai yang akan diteruskan dari luar dan KELUAR mewakili parameter yang akan digunakan untuk mengembalikan nilai di luar prosedur.

  • procedure-body berisi bagian yang dapat dieksekusi.

  • Kata kunci AS digunakan sebagai pengganti kata kunci IS untuk membuat prosedur mandiri.

Contoh

Contoh berikut membuat prosedur sederhana yang menampilkan string 'Hello World!' di layar saat dijalankan.

CREATE OR REPLACE PROCEDURE greetings 
AS 
BEGIN 
   dbms_output.put_line('Hello World!'); 
END; 
/

Ketika kode di atas dijalankan menggunakan prompt SQL, itu akan menghasilkan hasil sebagai berikut -

Procedure created.

Menjalankan Prosedur Mandiri

Prosedur mandiri dapat dilakukan dengan dua cara -

  • Menggunakan EXECUTE kata kunci

  • Memanggil nama prosedur dari blok PL / SQL

Prosedur di atas bernama 'greetings' dapat disebut dengan kata kunci LAKUKAN sebagai -

EXECUTE greetings;

Panggilan di atas akan menampilkan -

Hello World

PL/SQL procedure successfully completed.

Prosedurnya juga dapat dipanggil dari blok PL / SQL lain -

BEGIN 
   greetings; 
END; 
/

Panggilan di atas akan menampilkan -

Hello World  

PL/SQL procedure successfully completed.

Menghapus Prosedur Mandiri

Prosedur mandiri dihapus dengan DROP PROCEDUREpernyataan. Sintaks untuk menghapus prosedur adalah -

DROP PROCEDURE procedure-name;

Anda dapat membatalkan prosedur salam dengan menggunakan pernyataan berikut -

DROP PROCEDURE greetings;

Mode Parameter dalam Subprogram PL / SQL

Tabel berikut mencantumkan mode parameter dalam subprogram PL / SQL -

S.No Mode & Deskripsi Parameter
1

IN

Parameter IN memungkinkan Anda memberikan nilai ke subprogram. It is a read-only parameter. Di dalam subprogram, parameter IN bertindak seperti konstanta. Itu tidak dapat diberi nilai. Anda dapat mengirimkan konstanta, literal, variabel yang diinisialisasi, atau ekspresi sebagai parameter IN. Anda juga dapat menginisialisasinya ke nilai default; namun, dalam kasus itu, itu dihilangkan dari panggilan subprogram.It is the default mode of parameter passing. Parameters are passed by reference.

2

OUT

Parameter OUT mengembalikan nilai ke program pemanggil. Di dalam subprogram, parameter OUT bertindak seperti variabel. Anda dapat mengubah nilainya dan mereferensikan nilai setelah menetapkannya.The actual parameter must be variable and it is passed by value.

3

IN OUT

Sebuah IN OUTparameter meneruskan nilai awal ke subprogram dan mengembalikan nilai yang diperbarui ke pemanggil. Itu bisa diberi nilai dan nilainya bisa dibaca.

Parameter aktual yang sesuai dengan parameter formal IN OUT harus berupa variabel, bukan konstanta atau ekspresi. Parameter formal harus diberi nilai.Actual parameter is passed by value.

Contoh Mode Masuk & Keluar 1

Program ini menemukan minimal dua nilai. Di sini, prosedur mengambil dua angka menggunakan mode IN dan mengembalikan nilai minimumnya menggunakan parameter OUT.

DECLARE 
   a number; 
   b number; 
   c number;
PROCEDURE findMin(x IN number, y IN number, z OUT number) IS 
BEGIN 
   IF x < y THEN 
      z:= x; 
   ELSE 
      z:= y; 
   END IF; 
END;   
BEGIN 
   a:= 23; 
   b:= 45; 
   findMin(a, b, c); 
   dbms_output.put_line(' Minimum of (23, 45) : ' || c); 
END; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Minimum of (23, 45) : 23  

PL/SQL procedure successfully completed.

Contoh Mode Masuk & Keluar 2

Prosedur ini menghitung kuadrat nilai dari nilai yang diteruskan. Contoh ini menunjukkan bagaimana kita dapat menggunakan parameter yang sama untuk menerima nilai dan kemudian mengembalikan hasil lain.

DECLARE 
   a number; 
PROCEDURE squareNum(x IN OUT number) IS 
BEGIN 
  x := x * x; 
END;  
BEGIN 
   a:= 23; 
   squareNum(a); 
   dbms_output.put_line(' Square of (23): ' || a); 
END; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Square of (23): 529 

PL/SQL procedure successfully completed.

Metode untuk Meneruskan Parameter

Parameter aktual dapat dilewatkan dalam tiga cara -

  • Notasi posisi
  • Notasi bernama
  • Notasi campuran

Notasi Posisi

Dalam notasi posisi, Anda dapat memanggil prosedur sebagai -

findMin(a, b, c, d);

Dalam notasi posisi, parameter aktual pertama diganti dengan parameter formal pertama; parameter aktual kedua diganti dengan parameter formal kedua, dan seterusnya. Begitu,a diganti x, b diganti y, c diganti z dan d diganti m.

Notasi Bernama

Dalam notasi bernama, parameter aktual dikaitkan dengan parameter formal menggunakan arrow symbol ( => ). Panggilan prosedur akan seperti berikut -

findMin(x => a, y => b, z => c, m => d);

Notasi Campuran

Dalam notasi campuran, Anda dapat mencampur kedua notasi dalam pemanggilan prosedur; namun, notasi posisional harus mendahului notasi bernama.

Panggilan berikut ini sah -

findMin(a, b, c, m => d);

Namun, ini tidak legal:

findMin(x => a, b, c, d);