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.