PL / SQL - Keluaran DBMS

Pada bab ini, kita akan membahas Output DBMS di PL / SQL. ItuDBMS_OUTPUTadalah paket bawaan yang memungkinkan Anda menampilkan keluaran, men-debug informasi, dan mengirim pesan dari blok PL / SQL, subprogram, paket, dan pemicu. Kami telah menggunakan paket ini selama tutorial kami.

Mari kita lihat potongan kode kecil yang akan menampilkan semua tabel pengguna dalam database. Cobalah di database Anda untuk mencantumkan semua nama tabel -

BEGIN 
   dbms_output.put_line  (user || ' Tables in the database:'); 
   FOR t IN (SELECT table_name FROM user_tables) 
   LOOP 
      dbms_output.put_line(t.table_name); 
   END LOOP; 
END; 
/

DBMS_OUTPUT Subprogram

Paket DBMS_OUTPUT memiliki subprogram berikut -

S.No Subprogram & Tujuan
1

DBMS_OUTPUT.DISABLE;

Menonaktifkan keluaran pesan.

2

DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000);

Mengaktifkan keluaran pesan. Nilai NULL daribuffer_size mewakili ukuran buffer tidak terbatas.

3

DBMS_OUTPUT.GET_LINE (line OUT VARCHAR2, status OUT INTEGER);

Mengambil satu baris informasi yang di-buffer.

4

DBMS_OUTPUT.GET_LINES (lines OUT CHARARR, numlines IN OUT INTEGER);

Mengambil larik baris dari buffer.

5

DBMS_OUTPUT.NEW_LINE;

Menempatkan penanda akhir baris.

6

DBMS_OUTPUT.PUT(item IN VARCHAR2);

Menempatkan garis parsial di buffer.

7

DBMS_OUTPUT.PUT_LINE(item IN VARCHAR2);

Menempatkan garis di buffer.

Contoh

DECLARE 
   lines dbms_output.chararr; 
   num_lines number; 
BEGIN 
   -- enable the buffer with default size 20000 
   dbms_output.enable; 
   
   dbms_output.put_line('Hello Reader!'); 
   dbms_output.put_line('Hope you have enjoyed the tutorials!'); 
   dbms_output.put_line('Have a great time exploring pl/sql!'); 
  
   num_lines := 3; 
  
   dbms_output.get_lines(lines, num_lines); 
  
   FOR i IN 1..num_lines LOOP 
      dbms_output.put_line(lines(i)); 
   END LOOP; 
END; 
/

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

Hello Reader! 
Hope you have enjoyed the tutorials! 
Have a great time exploring pl/sql!  

PL/SQL procedure successfully completed.