पीएल / एसक्यूएल - पैकेज
इस अध्याय में, हम 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