PL / SQL - Berorientasi Objek

Pada bab ini, kita akan membahas PL / SQL Berorientasi Objek. PL / SQL memungkinkan mendefinisikan tipe objek, yang membantu dalam merancang database berorientasi objek di Oracle. Tipe objek memungkinkan Anda membuat tipe komposit. Menggunakan objek memungkinkan Anda untuk mengimplementasikan objek dunia nyata dengan struktur data dan metode tertentu untuk mengoperasikannya. Objek memiliki atribut dan metode. Atribut adalah properti suatu objek dan digunakan untuk menyimpan status objek; dan metode digunakan untuk memodelkan perilakunya.

Objek dibuat menggunakan pernyataan CREATE [OR REPLACE] TYPE. Berikut adalah contoh membuat fileaddress objek yang terdiri dari beberapa atribut -

CREATE OR REPLACE TYPE address AS OBJECT 
(house_no varchar2(10), 
 street varchar2(30), 
 city varchar2(20), 
 state varchar2(10), 
 pincode varchar2(10) 
); 
/

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

Type created.

Mari buat satu objek lagi customer dimana kita akan membungkusnya attributes dan methods bersama-sama memiliki perasaan berorientasi objek -

CREATE OR REPLACE TYPE customer AS OBJECT 
(code number(5), 
 name varchar2(30), 
 contact_no varchar2(12), 
 addr address, 
 member procedure display 
); 
/

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

Type created.

Instansiasi Objek

Mendefinisikan tipe objek memberikan cetak biru untuk objek tersebut. Untuk menggunakan objek ini, Anda perlu membuat instance dari objek ini. Anda dapat mengakses atribut dan metode objek menggunakan nama instance danthe access operator (.) sebagai berikut -

DECLARE 
   residence address; 
BEGIN 
   residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301'); 
   dbms_output.put_line('House No: '|| residence.house_no); 
   dbms_output.put_line('Street: '|| residence.street); 
   dbms_output.put_line('City: '|| residence.city); 
   dbms_output.put_line('State: '|| residence.state); 
   dbms_output.put_line('Pincode: '|| residence.pincode); 
END; 
/

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

House No: 103A 
Street: M.G.Road 
City: Jaipur 
State: Rajasthan 
Pincode: 201301  

PL/SQL procedure successfully completed.

Metode Anggota

Member methods digunakan untuk memanipulasi attributesdari objek. Anda memberikan deklarasi metode anggota sambil mendeklarasikan tipe objek. Badan objek mendefinisikan kode untuk metode anggota. Badan objek dibuat menggunakan pernyataan CREATE TYPE BODY.

Constructorsadalah fungsi yang mengembalikan objek baru sebagai nilainya. Setiap objek memiliki metode konstruktor yang ditentukan sistem. Nama konstruktor sama dengan tipe objek. Misalnya -

residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301');

Itu comparison methodsdigunakan untuk membandingkan objek. Ada dua cara untuk membandingkan objek -

Metode peta

Itu Map methodadalah fungsi yang diimplementasikan sedemikian rupa sehingga nilainya bergantung pada nilai atribut. Misalnya, untuk objek pelanggan, jika kode pelanggan sama untuk dua pelanggan, kedua pelanggan bisa jadi sama. Jadi hubungan antara dua objek ini akan bergantung pada nilai kode.

Metode pemesanan

Itu Order methodmengimplementasikan beberapa logika internal untuk membandingkan dua objek. Misalnya, untuk objek persegi panjang, persegi panjang lebih besar dari persegi panjang lainnya jika kedua sisinya lebih besar.

Menggunakan metode Map

Mari kita coba memahami konsep di atas menggunakan objek persegi panjang berikut -

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 member procedure display, 
 map member function measure return number 
); 
/

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

Type created.

Menciptakan tipe tubuh -

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN  
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   MAP MEMBER FUNCTION measure return number IS 
   BEGIN 
      return (sqrt(length*length + width*width)); 
   END measure; 
END; 
/

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

Type body created.

Sekarang menggunakan objek persegi panjang dan fungsi anggotanya -

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
   r3 rectangle; 
   inc_factor number := 5; 
BEGIN 
   r1 := rectangle(3, 4); 
   r2 := rectangle(5, 7); 
   r3 := r1.enlarge(inc_factor); 
   r3.display;  
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

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

Length: 8 
Width: 9 
Length: 5 
Width: 7  

PL/SQL procedure successfully completed.

Menggunakan metode Order

Sekarang, same effect could be achieved using an order method. Mari kita membuat ulang objek persegi panjang menggunakan metode order -

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member procedure display, 
 order member function measure(r rectangle) return number 
); 
/

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

Type created.

Menciptakan tipe tubuh -

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   ORDER MEMBER FUNCTION measure(r rectangle) return number IS 
   BEGIN 
      IF(sqrt(self.length*self.length + self.width*self.width)> 
         sqrt(r.length*r.length + r.width*r.width)) then 
         return(1); 
      ELSE 
         return(-1); 
      END IF; 
   END measure; 
END; 
/

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

Type body created.

Menggunakan objek persegi panjang dan fungsi anggotanya -

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
BEGIN 
   r1 := rectangle(23, 44); 
   r2 := rectangle(15, 17); 
   r1.display; 
   r2.display; 
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

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

Length: 23 
Width: 44 
Length: 15 
Width: 17 
Length: 23 
Width: 44 

PL/SQL procedure successfully completed.

Warisan untuk Objek PL / SQL

PL / SQL memungkinkan pembuatan objek dari objek dasar yang ada. Untuk mengimplementasikan pewarisan, objek dasar harus dideklarasikan sebagaiNOT FINAL. Standarnya adalahFINAL.

Program berikut menggambarkan warisan di Objek PL / SQL. Mari kita buat objek lain bernamaTableTop, ini diwarisi dari objek Rectangle. Untuk ini, kita perlu membuat objek persegi panjang dasar -

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 NOT FINAL member procedure display) NOT FINAL 
/

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

Type created.

Menciptakan tubuh tipe dasar -

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display; 
END; 
/

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

Type body created.

Membuat meja objek anak -

CREATE OR REPLACE TYPE tabletop UNDER rectangle 
(   
   material varchar2(20), 
   OVERRIDING member procedure display 
) 
/

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

Type created.

Membuat tubuh tipe untuk meja objek anak

CREATE OR REPLACE TYPE BODY tabletop AS 
OVERRIDING MEMBER PROCEDURE display IS 
BEGIN 
   dbms_output.put_line('Length: '|| length); 
   dbms_output.put_line('Width: '|| width); 
   dbms_output.put_line('Material: '|| material); 
END display; 
/

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

Type body created.

Menggunakan objek meja dan fungsi anggotanya -

DECLARE 
   t1 tabletop; 
   t2 tabletop; 
BEGIN 
   t1:= tabletop(20, 10, 'Wood'); 
   t2 := tabletop(50, 30, 'Steel'); 
   t1.display; 
   t2.display; 
END;
/

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

Length: 20 
Width: 10 
Material: Wood 
Length: 50 
Width: 30 
Material: Steel  

PL/SQL procedure successfully completed.

Objek Abstrak di PL / SQL

Itu NOT INSTANTIABLEklausa memungkinkan Anda untuk mendeklarasikan objek abstrak. Anda tidak dapat menggunakan objek abstrak sebagaimana adanya; Anda harus membuat subtipe atau tipe anak dari objek tersebut untuk menggunakan fungsinya.

Sebagai contoh,

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 NOT INSTANTIABLE NOT FINAL MEMBER PROCEDURE display)  
 NOT INSTANTIABLE NOT FINAL 
/

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

Type created.