PL / SQL - संग्रह
इस अध्याय में, हम PL / SQL में संग्रह की चर्चा करेंगे। एक संग्रह एक समान डेटा प्रकार वाले तत्वों का एक आदेशित समूह है। प्रत्येक तत्व को एक अद्वितीय सबस्क्रिप्ट द्वारा पहचाना जाता है जो संग्रह में इसकी स्थिति का प्रतिनिधित्व करता है।
PL / SQL तीन संग्रह प्रकार प्रदान करता है -
- सूचकांक-द्वारा तालिकाओं या साहचर्य सरणी
- नेस्टेड टेबल
- परिवर्तनीय-आकार की सरणी या Varray
ओरेकल प्रलेखन प्रत्येक प्रकार के संग्रह के लिए निम्नलिखित विशेषताएं प्रदान करता है -
संग्रह का प्रकार | तत्वों की संख्या | सदस्यता प्रकार | घना या विरल | जहाँ बनाया गया | वस्तु प्रकार गुण हो सकते हैं |
---|---|---|---|---|---|
साहचर्य सरणी (या अनुक्रमणिका-तालिका) | असीम | स्ट्रिंग या पूर्णांक | भी | केवल PL / SQL ब्लॉक में | नहीं |
नेस्टेड टेबल | असीम | पूर्णांक | घना शुरू होता है, विरल बन सकता है | या तो पीएल / एसक्यूएल ब्लॉक में या स्कीमा स्तर पर | हाँ |
चर (वर्ण) | घिरे | पूर्णांक | हमेशा सघन | या तो पीएल / एसक्यूएल ब्लॉक में या स्कीमा स्तर पर | हाँ |
हम पहले ही अध्याय में विचरण पर चर्चा कर चुके हैं 'PL/SQL arrays'। इस अध्याय में, हम PL / SQL तालिकाओं पर चर्चा करेंगे।
दोनों प्रकार के PL / SQL टेबल, यानी, अनुक्रमणिका-द्वारा तालिकाओं और नेस्टेड तालिकाओं में समान संरचना होती है और उनकी पंक्तियों को सबस्क्रिप्ट नोटेशन का उपयोग करके एक्सेस किया जाता है। हालाँकि, ये दो प्रकार की टेबल एक पहलू में भिन्न होती हैं; नेस्टेड टेबल को एक डेटाबेस कॉलम में संग्रहीत किया जा सकता है और इंडेक्स-बाय टेबल नहीं कर सकते हैं।
सूचकांक-द्वारा तालिका
एक index-by तालिका (जिसे एक भी कहा जाता है associative array) का एक सेट है key-valueजोड़े। प्रत्येक कुंजी अद्वितीय है और इसी मूल्य का पता लगाने के लिए उपयोग किया जाता है। कुंजी या तो पूर्णांक या एक स्ट्रिंग हो सकती है।
अनुक्रमणिका-द्वारा तालिका निम्न सिंटैक्स का उपयोग करके बनाई गई है। यहाँ, हम एक बना रहे हैंindex-by नाम की मेज table_nameजिनमें से चाबियाँ सबस्क्रिप्ट_टाइप और संबद्ध मानों की होंगी, एलिमेंट_टाइप की होंगी
TYPE type_name IS TABLE OF element_type [NOT NULL] INDEX BY subscript_type;
table_name type_name;
उदाहरण
उदाहरण के बाद पता चलता है कि नामों के साथ पूर्णांक मानों को संग्रहीत करने के लिए एक तालिका कैसे बनाई जाती है और बाद में यह नामों की एक ही सूची प्रिंट करता है।
DECLARE
TYPE salary IS TABLE OF NUMBER INDEX BY VARCHAR2(20);
salary_list salary;
name VARCHAR2(20);
BEGIN
-- adding elements to the table
salary_list('Rajnish') := 62000;
salary_list('Minakshi') := 75000;
salary_list('Martin') := 100000;
salary_list('James') := 78000;
-- printing the table
name := salary_list.FIRST;
WHILE name IS NOT null LOOP
dbms_output.put_line
('Salary of ' || name || ' is ' || TO_CHAR(salary_list(name)));
name := salary_list.NEXT(name);
END LOOP;
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Salary of James is 78000
Salary of Martin is 100000
Salary of Minakshi is 75000
Salary of Rajnish is 62000
PL/SQL procedure successfully completed.
उदाहरण
इंडेक्स-बाय टेबल के तत्व भी हो सकते हैं %ROWTYPE किसी भी डेटाबेस तालिका या %TYPEकिसी भी डेटाबेस तालिका क्षेत्र के। निम्नलिखित उदाहरण अवधारणा को दर्शाता है। हम उपयोग करेंगेCUSTOMERS हमारे डेटाबेस में तालिका के रूप में संग्रहीत -
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 |
+----+----------+-----+-----------+----------+
DECLARE
CURSOR c_customers is
select name from customers;
TYPE c_list IS TABLE of customers.Name%type INDEX BY binary_integer;
name_list c_list;
counter integer :=0;
BEGIN
FOR n IN c_customers LOOP
counter := counter +1;
name_list(counter) := n.name;
dbms_output.put_line('Customer('||counter||'):'||name_lis t(counter));
END LOOP;
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Customer(1): Ramesh
Customer(2): Khilan
Customer(3): kaushik
Customer(4): Chaitali
Customer(5): Hardik
Customer(6): Komal
PL/SQL procedure successfully completed
नेस्टेड टेबल
ए nested tableतत्वों की एक मनमानी संख्या के साथ एक आयामी सरणी की तरह है। हालाँकि, एक नेस्टेड तालिका निम्नलिखित पहलुओं में एक सरणी से भिन्न होती है -
एक सरणी में तत्वों की एक घोषित संख्या होती है, लेकिन एक नेस्टेड तालिका नहीं होती है। नेस्टेड टेबल का आकार गतिशील रूप से बढ़ सकता है।
एक सरणी सदैव सघन होती है, अर्थात इसमें सदैव निरंतर अंश होते हैं। एक नेस्टेड सरणी शुरू में घनी होती है, लेकिन तत्वों से इसे हटा दिए जाने पर यह विरल हो सकता है।
एक नेस्टेड तालिका निम्नलिखित सिंटैक्स का उपयोग करके बनाई गई है -
TYPE type_name IS TABLE OF element_type [NOT NULL];
table_name type_name;
यह घोषणा एक की घोषणा के समान है index-by टेबल, लेकिन वहाँ कोई नहीं है INDEX BY खंड।
एक नेस्टेड तालिका को एक डेटाबेस कॉलम में संग्रहीत किया जा सकता है। यह आगे SQL संचालन को आसान बनाने के लिए इस्तेमाल किया जा सकता है, जहां आप एक बड़ी तालिका के साथ एकल-स्तंभ तालिका में शामिल होते हैं। डेटाबेस में एक सहयोगी सरणी संग्रहीत नहीं की जा सकती।
उदाहरण
निम्नलिखित उदाहरण नेस्टेड टेबल के उपयोग का वर्णन करते हैं -
DECLARE
TYPE names_table IS TABLE OF VARCHAR2(10);
TYPE grades IS TABLE OF INTEGER;
names names_table;
marks grades;
total integer;
BEGIN
names := names_table('Kavita', 'Pritam', 'Ayan', 'Rishav', 'Aziz');
marks:= grades(98, 97, 78, 87, 92);
total := names.count;
dbms_output.put_line('Total '|| total || ' Students');
FOR i IN 1 .. total LOOP
dbms_output.put_line('Student:'||names(i)||', Marks:' || marks(i));
end loop;
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Total 5 Students
Student:Kavita, Marks:98
Student:Pritam, Marks:97
Student:Ayan, Marks:78
Student:Rishav, Marks:87
Student:Aziz, Marks:92
PL/SQL procedure successfully completed.
उदाहरण
के तत्व nested table भी हो सकता है %ROWTYPEकिसी भी डेटाबेस तालिका या किसी भी डेटाबेस तालिका क्षेत्र के% प्रकार के। निम्नलिखित उदाहरण अवधारणा को दर्शाता है। हम अपने डेटाबेस में संग्रहीत ग्राहक तालिका का उपयोग इस प्रकार करेंगे -
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 |
+----+----------+-----+-----------+----------+
DECLARE
CURSOR c_customers is
SELECT name FROM customers;
TYPE c_list IS TABLE of customerS.No.ame%type;
name_list c_list := c_list();
counter integer :=0;
BEGIN
FOR n IN c_customers LOOP
counter := counter +1;
name_list.extend;
name_list(counter) := n.name;
dbms_output.put_line('Customer('||counter||'):'||name_list(counter));
END LOOP;
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Customer(1): Ramesh
Customer(2): Khilan
Customer(3): kaushik
Customer(4): Chaitali
Customer(5): Hardik
Customer(6): Komal
PL/SQL procedure successfully completed.
संग्रह के तरीके
PL / SQL बिल्ट-इन कलेक्शन मेथड्स प्रदान करता है जो संग्रह को उपयोग में आसान बनाते हैं। निम्न तालिका विधियों और उनके उद्देश्य को सूचीबद्ध करती है -
S.No | विधि का नाम और उद्देश्य |
---|---|
1 | EXISTS(n) यदि संग्रह में nth तत्व मौजूद है, तो TRUE लौटाता है; अन्यथा FALSE देता है। |
2 | COUNT वर्तमान में संग्रहित तत्वों की संख्या लौटाता है। |
3 | LIMIT एक संग्रह के अधिकतम आकार की जाँच करता है। |
4 | FIRST पूर्णांक में पहले (सबसे छोटे) अनुक्रमणिका संख्याओं को देता है जो पूर्णांक सदस्यता का उपयोग करता है। |
5 | LAST पूर्णांक सदस्यता का उपयोग करने वाले संग्रह में अंतिम (सबसे बड़ा) अनुक्रमणिका संख्या देता है। |
6 | PRIOR(n) एक n संग्रह में सूचकांक n से पहले सूचकांक संख्या लौटाता है। |
7 | NEXT(n) अनुक्रमणिका संख्या लौटाता है जो अनुक्रमणिका n को सफल करता है। |
8 | EXTEND एक संग्रह के लिए एक अशक्त तत्व को लागू करता है। |
9 | EXTEND(n) एक संग्रह के लिए n अशक्त तत्वों को लागू करता है। |
10 | EXTEND(n,i) संलग्न कर देता है nएक संग्रह में i वें तत्व की प्रतियां । |
1 1 | TRIM एक संग्रह के अंत से एक तत्व निकालता है। |
12 | TRIM(n) हटा देगा n एक संग्रह के अंत से तत्व। |
13 | DELETE किसी संग्रह से सभी तत्वों को निकालता है, COUNT को 0 पर सेट कर रहा है। |
14 | DELETE(n) निकालता है nthएक संख्यात्मक कुंजी या एक नेस्टेड तालिका के साथ एक सहयोगी सरणी से तत्व। यदि साहचर्य सरणी में स्ट्रिंग कुंजी है, तो कुंजी मान के अनुरूप तत्व हटा दिया जाता है। अगरn शून्य है, DELETE(n) कुछ नहीं करता। |
15 | DELETE(m,n) श्रेणी के सभी तत्वों को निकालता है m..nएक सहयोगी सरणी या नेस्टेड तालिका से। अगरm से बड़ा है n या अगर m या n शून्य है, DELETE(m,n) कुछ नहीं करता। |
संग्रह के अपवाद
निम्न तालिका संग्रह अपवाद प्रदान करती है और जब वे उठाए जाते हैं -
संग्रह अपवाद | स्थिति में उठाया |
---|---|
COLLECTION_IS_NULL | आप एक परमाणु शून्य संग्रह पर काम करने की कोशिश करते हैं। |
कोई डेटा नहीं मिला | एक सबस्क्रिप्ट एक तत्व को हटाता है, जिसे हटा दिया गया था, या साहचर्य सरणी का कोई नहीं तत्व। |
SUBSCRIPT_BEYOND_COUNT | एक सबस्क्रिप्ट एक संग्रह में तत्वों की संख्या से अधिक है। |
SUBSCRIPT_OUTSIDE_LIMIT | अनुमत सीमा के बाहर एक सबस्क्रिप्ट है। |
VALUE_ERROR | एक सबस्क्रिप्ट कुंजी प्रकार के लिए शून्य या परिवर्तनीय नहीं है। यह अपवाद तब हो सकता है जब कुंजी को ए के रूप में परिभाषित किया गया होPLS_INTEGER रेंज, और सबस्क्रिप्ट इस रेंज के बाहर है। |