PL / SQL - Paket

Pada bab ini, kita akan membahas Paket-Paket di PL / SQL. Paket adalah objek skema yang mengelompokkan tipe PL / SQL, variabel, dan subprogram yang terkait secara logis.

Sebuah paket akan memiliki dua bagian wajib -

  • Spesifikasi paket
  • Isi atau definisi paket

Spesifikasi Paket

Spesifikasi adalah antarmuka ke paket. Itu hanyaDECLARESjenis, variabel, konstanta, pengecualian, kursor, dan subprogram yang dapat dirujuk dari luar paket. Dengan kata lain, ini berisi semua informasi tentang isi paket, tetapi tidak termasuk kode untuk subprogram.

Semua objek yang ditempatkan dalam spesifikasi dipanggil publicbenda. Subprogram apa pun yang tidak ada dalam spesifikasi paket tetapi diberi kode di badan paket disebut aprivate obyek.

Cuplikan kode berikut menunjukkan spesifikasi paket yang memiliki satu prosedur. Anda dapat menentukan banyak variabel global dan beberapa prosedur atau fungsi di dalam sebuah paket.

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

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Package created.

Isi Paket

Badan paket memiliki kode untuk berbagai metode yang dideklarasikan dalam spesifikasi paket dan deklarasi pribadi lainnya, yang disembunyikan dari kode di luar paket.

Itu CREATE PACKAGE BODYPernyataan digunakan untuk membuat badan paket. Potongan kode berikut menunjukkan deklarasi badan paket untukcust_salpaket yang dibuat di atas. Saya berasumsi bahwa kita sudah memiliki tabel CUSTOMERS yang dibuat di database kita seperti yang disebutkan di bab PL / SQL - Variables .

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; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Package body created.

Menggunakan Elemen Paket

Elemen paket (variabel, prosedur atau fungsi) diakses dengan sintaks berikut -

package_name.element_name;

Pertimbangkan, kami telah membuat paket di atas dalam skema database kami, program berikut menggunakan find_sal metode dari cust_sal paket -

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

Ketika kode di atas dijalankan pada prompt SQL, ia meminta untuk memasukkan ID pelanggan dan ketika Anda memasukkan ID, ini akan menampilkan gaji yang sesuai sebagai berikut -

Enter value for cc_id: 1 
Salary: 3000 

PL/SQL procedure successfully completed.

Contoh

Program berikut menyediakan paket yang lebih lengkap. Kami akan menggunakan tabel PELANGGAN yang disimpan dalam database kami dengan catatan berikut -

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 | 
+----+----------+-----+-----------+----------+

Spesifikasi Paket

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; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu membuat paket di atas dan menampilkan hasil berikut -

Package created.

Membuat Badan Paket

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; 
/

Contoh di atas memanfaatkan file nested table. Kita akan membahas konsep tabel bersarang di bab berikutnya.

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Package body created.

Menggunakan The Package

Program berikut menggunakan metode yang dideklarasikan dan didefinisikan dalam paket 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; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

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