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.