PL / SQL - ऑब्जेक्ट ओरिएंटेड
इस अध्याय में, हम ऑब्जेक्ट-ओरिएंटेड PL / SQL पर चर्चा करेंगे। पीएल / एसक्यूएल एक ऑब्जेक्ट प्रकार को परिभाषित करने की अनुमति देता है, जो ओरेकल में ऑब्जेक्ट-ओरिएंटेड डेटाबेस को डिजाइन करने में मदद करता है। ऑब्जेक्ट प्रकार आपको समग्र प्रकार बनाने की अनुमति देता है। वस्तुओं का उपयोग करने से आपको वास्तविक दुनिया की वस्तुओं को डेटा की विशिष्ट संरचना और इसे संचालित करने के तरीकों के साथ लागू करने की अनुमति मिलती है। वस्तुओं में विशेषताएँ और विधियाँ होती हैं। विशेषताएँ एक वस्तु के गुण हैं और इसका उपयोग किसी वस्तु की अवस्था को संचय करने के लिए किया जाता है; और तरीकों का उपयोग इसके व्यवहार के मॉडलिंग के लिए किया जाता है।
वस्तुओं को सृजित [या उत्तर] प्रकार के कथन का उपयोग करके बनाया जाता है। निम्नलिखित एक सरल बनाने के लिए एक उदाहरण हैaddress कुछ विशेषताओं से मिलकर वस्तु -
CREATE OR REPLACE TYPE address AS OBJECT
(house_no varchar2(10),
street varchar2(30),
city varchar2(20),
state varchar2(10),
pincode varchar2(10)
);
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
एक और वस्तु बनाते हैं customer हम कहाँ लपेटेंगे attributes तथा methods साथ में वस्तु-उन्मुख भावना है -
CREATE OR REPLACE TYPE customer AS OBJECT
(code number(5),
name varchar2(30),
contact_no varchar2(12),
addr address,
member procedure display
);
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
किसी वस्तु को तत्काल बनाना
ऑब्जेक्ट प्रकार को परिभाषित करना ऑब्जेक्ट के लिए एक खाका प्रदान करता है। इस ऑब्जेक्ट का उपयोग करने के लिए, आपको इस ऑब्जेक्ट के उदाहरण बनाने की आवश्यकता है। आप उदाहरण नाम और का उपयोग करके ऑब्जेक्ट की विशेषताओं और विधियों तक पहुंच सकते हैंthe access operator (.) निम्नानुसार है -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
House No: 103A
Street: M.G.Road
City: Jaipur
State: Rajasthan
Pincode: 201301
PL/SQL procedure successfully completed.
सदस्य विधियाँ
Member methods हेरफेर करने के लिए उपयोग किया जाता है attributesवस्तु का। आप ऑब्जेक्ट प्रकार की घोषणा करते हुए एक सदस्य विधि की घोषणा प्रदान करते हैं। ऑब्जेक्ट बॉडी सदस्य विधियों के लिए कोड को परिभाषित करता है। ऑब्जेक्ट बॉडी क्रिएट टाइप बॉडी स्टेटमेंट का उपयोग करके बनाई गई है।
Constructorsऐसे कार्य हैं जो एक नई वस्तु को उसके मूल्य के रूप में लौटाते हैं। प्रत्येक वस्तु में एक प्रणाली परिभाषित निर्माण विधि होती है। कंस्ट्रक्टर का नाम ऑब्जेक्ट प्रकार के समान है। उदाहरण के लिए -
residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301');
comparison methodsवस्तुओं की तुलना करने के लिए उपयोग किया जाता है। वस्तुओं की तुलना करने के दो तरीके हैं -
नक्शा विधि
Map methodएक फ़ंक्शन इस तरह से कार्यान्वित किया जाता है कि उसका मूल्य विशेषताओं के मूल्य पर निर्भर करता है। उदाहरण के लिए, ग्राहक वस्तु के लिए, यदि ग्राहक कोड दो ग्राहकों के लिए समान है, तो दोनों ग्राहक समान हो सकते हैं। इसलिए इन दोनों वस्तुओं के बीच का संबंध कोड के मूल्य पर निर्भर करेगा।
आदेश विधि
Order methodदो वस्तुओं की तुलना के लिए कुछ आंतरिक तर्क को लागू करता है। उदाहरण के लिए, एक आयत वस्तु के लिए, एक आयत दूसरी आयत से बड़ी होती है यदि उसके दोनों किनारे बड़े होते हैं।
मानचित्र विधि का उपयोग करना
आइये हम निम्नलिखित आयत वस्तु का उपयोग करके उपरोक्त अवधारणाओं को समझने की कोशिश करते हैं -
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
);
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
टाइप बॉडी बनाना -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type body created.
अब आयत वस्तु और उसके सदस्य कार्यों का उपयोग करना -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length: 8
Width: 9
Length: 5
Width: 7
PL/SQL procedure successfully completed.
ऑर्डर विधि का उपयोग करना
अब same effect could be achieved using an order method। आइए हम एक ऑर्डर विधि का उपयोग करके आयत वस्तु को फिर से बनाएँ -
CREATE OR REPLACE TYPE rectangle AS OBJECT
(length number,
width number,
member procedure display,
order member function measure(r rectangle) return number
);
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
टाइप बॉडी बनाना -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type body created.
आयत वस्तु और उसके सदस्य कार्यों का उपयोग करना -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length: 23
Width: 44
Length: 15
Width: 17
Length: 23
Width: 44
PL/SQL procedure successfully completed.
पीएल / एसक्यूएल ऑब्जेक्ट्स के लिए विरासत
PL / SQL मौजूदा बेस ऑब्जेक्ट से ऑब्जेक्ट बनाने की अनुमति देता है। विरासत को लागू करने के लिए, आधार वस्तुओं को घोषित किया जाना चाहिएNOT FINAL। डिफ़ॉल्ट हैFINAL।
निम्न प्रोग्राम PL / SQL ऑब्जेक्ट्स में इनहेरिटेंस का वर्णन करते हैं। नाम की एक और वस्तु बनाते हैंTableTop, यह आयत वस्तु से विरासत में मिला है। इसके लिए, हमें आधार आयत वस्तु बनाने की आवश्यकता है -
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
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
बेस टाइप बॉडी बनाना -
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type body created.
बच्चे वस्तु टेबलटॉप बनाना -
CREATE OR REPLACE TYPE tabletop UNDER rectangle
(
material varchar2(20),
OVERRIDING member procedure display
)
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.
चाइल्ड ऑब्जेक्ट टेबलटॉप के लिए टाइप बॉडी बनाना
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;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type body created.
टेबलटॉप ऑब्जेक्ट और उसके सदस्य कार्यों का उपयोग करना -
DECLARE
t1 tabletop;
t2 tabletop;
BEGIN
t1:= tabletop(20, 10, 'Wood');
t2 := tabletop(50, 30, 'Steel');
t1.display;
t2.display;
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length: 20
Width: 10
Material: Wood
Length: 50
Width: 30
Material: Steel
PL/SQL procedure successfully completed.
पीएल / एसक्यूएल में सार वस्तुएं
NOT INSTANTIABLEखण्ड आपको एक अमूर्त वस्तु घोषित करने की अनुमति देता है। आप एक अमूर्त वस्तु का उपयोग नहीं कर सकते हैं जैसा कि यह है; आपको अपनी कार्यक्षमता का उपयोग करने के लिए इस तरह की वस्तुओं का एक उपप्रकार या बाल प्रकार बनाना होगा।
उदाहरण के लिए,
CREATE OR REPLACE TYPE rectangle AS OBJECT
(length number,
width number,
NOT INSTANTIABLE NOT FINAL MEMBER PROCEDURE display)
NOT INSTANTIABLE NOT FINAL
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Type created.