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 रेंज, और सबस्क्रिप्ट इस रेंज के बाहर है।