PL / SQL - Fungsi

Pada bab ini, kita akan membahas fungsi-fungsi dalam PL / SQL. Suatu fungsi sama dengan prosedur kecuali ia mengembalikan nilai. Oleh karena itu, semua pembahasan pada bab sebelumnya juga berlaku untuk fungsi.

Membuat Fungsi

Fungsi mandiri dibuat menggunakan CREATE FUNCTIONpernyataan. Sintaks yang disederhanakan untuk fileCREATE OR REPLACE PROCEDURE pernyataannya adalah sebagai berikut -

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

Dimana,

  • function-name menentukan nama fungsinya.

  • Opsi [ATAU GANTI] memungkinkan modifikasi fungsi yang sudah ada.

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

  • Fungsi tersebut harus mengandung a return pernyataan.

  • The RETURN klausul menentukan jenis data yang Anda akan kembali dari fungsi.

  • function-body berisi bagian yang dapat dieksekusi.

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

Contoh

Contoh berikut mengilustrasikan cara membuat dan memanggil fungsi mandiri. Fungsi ini mengembalikan jumlah PELANGGAN di tabel pelanggan.

Kami akan menggunakan tabel CUSTOMERS, yang telah kami buat di bab Variabel PL / SQL -

Select * from customers; 
 
+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

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

Function created.

Memanggil Fungsi

Saat membuat fungsi, Anda memberikan definisi tentang apa yang harus dilakukan fungsi tersebut. Untuk menggunakan suatu fungsi, Anda harus memanggil fungsi tersebut untuk melakukan tugas yang ditentukan. Ketika program memanggil suatu fungsi, kontrol program dipindahkan ke fungsi yang dipanggil.

Fungsi yang dipanggil melakukan tugas yang ditentukan dan kapan pernyataan kembaliannya dijalankan atau saat last end statement tercapai, ia mengembalikan kontrol program ke program utama.

Untuk memanggil suatu fungsi, Anda hanya perlu meneruskan parameter yang diperlukan bersama dengan nama fungsi dan jika fungsi mengembalikan nilai, maka Anda dapat menyimpan nilai yang dikembalikan. Program berikut memanggil fungsi tersebuttotalCustomers dari blok anonim -

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

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

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

Contoh

Contoh berikut menunjukkan Mendeklarasikan, Mendefinisikan, dan Memanggil Fungsi PL / SQL Sederhana yang menghitung dan mengembalikan maksimal dua nilai.

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

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

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

Fungsi Rekursif PL / SQL

Kita telah melihat bahwa suatu program atau subprogram dapat memanggil subprogram lain. Ketika sebuah subprogram memanggil dirinya sendiri, itu disebut sebagai panggilan rekursif dan prosesnya dikenal sebagairecursion.

Untuk mengilustrasikan konsep tersebut, mari kita hitung faktorial sebuah bilangan. Faktorial bilangan n didefinisikan sebagai -

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

Program berikut menghitung faktorial dari bilangan tertentu dengan memanggil dirinya sendiri secara rekursif -

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

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

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.