पीएल / एसक्यूएल - पैकेज

इस अध्याय में, हम PL / SQL में संकुल पर चर्चा करेंगे। पैकेज स्कीमा ऑब्जेक्ट हैं जो समूह तार्किक रूप से PL / SQL प्रकार, चर और उपप्रोग्राम से संबंधित होते हैं।

एक पैकेज में दो अनिवार्य भाग होंगे -

  • पैकेज विनिर्देश
  • पैकेज बॉडी या परिभाषा

पैकेज विशिष्टता

विनिर्देश पैकेज का इंटरफ़ेस है। यह बिल्कुलDECLARESप्रकार, चर, स्थिरांक, अपवाद, शाप, और उपप्रोग्राम जो पैकेज के बाहर से संदर्भित किए जा सकते हैं। दूसरे शब्दों में, इसमें पैकेज की सामग्री के बारे में सभी जानकारी होती है, लेकिन उपप्रोग्राम के लिए कोड को शामिल नहीं करता है।

विनिर्देश में रखी गई सभी वस्तुओं को कहा जाता है publicवस्तुओं। कोई भी उपप्रोग्राम पैकेज विनिर्देश में नहीं है, लेकिन पैकेज निकाय में कोडित को कहा जाता हैprivate वस्तु।

निम्न कोड स्निपेट एक एकल प्रक्रिया वाले एक पैकेज विनिर्देश को दर्शाता है। आपके पास कई वैश्विक चर और पैकेज के अंदर कई प्रक्रियाएं या कार्य हो सकते हैं।

CREATE PACKAGE cust_sal AS 
   PROCEDURE find_sal(c_id customers.id%type); 
END cust_sal; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Package created.

पैकेज बॉडी

पैकेज बॉडी में पैकेज विनिर्देश और अन्य निजी घोषणाओं में घोषित विभिन्न तरीकों के कोड होते हैं, जो पैकेज के बाहर कोड से छिपे होते हैं।

CREATE PACKAGE BODYस्टेटमेंट का उपयोग पैकेज बॉडी बनाने के लिए किया जाता है। निम्नलिखित कोड स्निपेट पैकेज बॉडी घोषणा को दर्शाता हैcust_salपैकेज ऊपर बनाया गया। मैंने मान लिया कि हमारे पास पहले से ही हमारे डेटाबेस में निर्मित ग्राहक तालिका है जैसा कि पीएल / एसक्यूएल - वेरिएबल्स अध्याय में वर्णित है ।

CREATE OR REPLACE PACKAGE BODY cust_sal AS  
   
   PROCEDURE find_sal(c_id customers.id%TYPE) IS 
   c_sal customers.salary%TYPE; 
   BEGIN 
      SELECT salary INTO c_sal 
      FROM customers 
      WHERE id = c_id; 
      dbms_output.put_line('Salary: '|| c_sal); 
   END find_sal; 
END cust_sal; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Package body created.

पैकेज तत्वों का उपयोग करना

पैकेज तत्वों (चर, प्रक्रिया या कार्य) को निम्नलिखित सिंटैक्स के साथ एक्सेस किया जाता है -

package_name.element_name;

गौर करें, हमने पहले ही अपने डेटाबेस स्कीमा में उपरोक्त पैकेज बनाया है, निम्न प्रोग्राम का उपयोग करता है find_sal की विधि cust_sal पैकेज -

DECLARE 
   code customers.id%type := &cc_id; 
BEGIN 
   cust_sal.find_sal(code); 
END; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह ग्राहक आईडी दर्ज करने का संकेत देता है और जब आप एक आईडी दर्ज करते हैं, तो यह निम्न वेतन को निम्नानुसार प्रदर्शित करता है -

Enter value for cc_id: 1 
Salary: 3000 

PL/SQL procedure successfully completed.

उदाहरण

निम्न प्रोग्राम एक अधिक पूर्ण पैकेज प्रदान करता है। हम निम्नलिखित अभिलेखों के साथ हमारे डेटाबेस में संग्रहीत ग्राहक तालिका का उपयोग करेंगे -

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  3000.00 | 
|  2 | Khilan   |  25 | Delhi     |  3000.00 | 
|  3 | kaushik  |  23 | Kota      |  3000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  7500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  9500.00 | 
|  6 | Komal    |  22 | MP        |  5500.00 | 
+----+----------+-----+-----------+----------+

पैकेज विशिष्टता

CREATE OR REPLACE PACKAGE c_package AS 
   -- Adds a customer 
   PROCEDURE addCustomer(c_id   customers.id%type, 
   c_name  customerS.No.ame%type, 
   c_age  customers.age%type, 
   c_addr customers.address%type,  
   c_sal  customers.salary%type); 
   
   -- Removes a customer 
   PROCEDURE delCustomer(c_id  customers.id%TYPE); 
   --Lists all customers 
   PROCEDURE listCustomer; 
  
END c_package; 
/

जब SQL कोड पर उपरोक्त कोड निष्पादित किया जाता है, तो यह उपरोक्त पैकेज बनाता है और निम्न परिणाम प्रदर्शित करता है -

Package created.

पैकेज बॉडी बनाना

CREATE OR REPLACE PACKAGE BODY c_package AS 
   PROCEDURE addCustomer(c_id  customers.id%type, 
      c_name customerS.No.ame%type, 
      c_age  customers.age%type, 
      c_addr  customers.address%type,  
      c_sal   customers.salary%type) 
   IS 
   BEGIN 
      INSERT INTO customers (id,name,age,address,salary) 
         VALUES(c_id, c_name, c_age, c_addr, c_sal); 
   END addCustomer; 
   
   PROCEDURE delCustomer(c_id   customers.id%type) IS 
   BEGIN 
      DELETE FROM customers 
      WHERE id = c_id; 
   END delCustomer;  
   
   PROCEDURE listCustomer IS 
   CURSOR c_customers is 
      SELECT  name FROM customers; 
   TYPE c_list is TABLE OF customers.Name%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 listCustomer;
   
END c_package; 
/

उपरोक्त उदाहरण का उपयोग करता है nested table। हम अगले अध्याय में नेस्टेड टेबल की अवधारणा पर चर्चा करेंगे।

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Package body created.

पैकेज का उपयोग करना

निम्न प्रोग्राम पैकेज c_package में घोषित और परिभाषित विधियों का उपयोग करता है ।

DECLARE 
   code customers.id%type:= 8; 
BEGIN 
   c_package.addcustomer(7, 'Rajnish', 25, 'Chennai', 3500); 
   c_package.addcustomer(8, 'Subham', 32, 'Delhi', 7500); 
   c_package.listcustomer; 
   c_package.delcustomer(code); 
   c_package.listcustomer; 
END; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal 
Customer(7): Rajnish 
Customer(8): Subham 
Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal
Customer(7): Rajnish 

PL/SQL procedure successfully completed