PL / SQL - DBMS आउटपुट

इस अध्याय में, हम पीएल / एसक्यूएल में डीबीएमएस आउटपुट पर चर्चा करेंगे। DBMS_OUTPUTएक अंतर्निहित पैकेज है जो आपको आउटपुट, डिबगिंग जानकारी प्रदर्शित करने और PL / SQL ब्लॉक, उपप्रोग्राम, पैकेज और ट्रिगर से संदेश भेजने में सक्षम बनाता है। हमने पहले ही अपने ट्यूटोरियल में इस पैकेज का उपयोग किया है।

आइए हम एक छोटे से कोड स्निपेट को देखें जो डेटाबेस के सभी उपयोगकर्ता तालिकाओं को प्रदर्शित करेगा। सभी तालिका नामों को सूचीबद्ध करने के लिए अपने डेटाबेस में इसे आज़माएं -

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 उपप्रोग्राम

DBMS_OUTPUT पैकेज में निम्न उपप्रोग्राम हैं -

S.No उपप्रोग्राम और उद्देश्य
1

DBMS_OUTPUT.DISABLE;

संदेश आउटपुट अक्षम करता है।

2

DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000);

संदेश आउटपुट सक्षम करता है। का एक पूर्ण मानbuffer_size असीमित बफर आकार का प्रतिनिधित्व करता है।

3

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

बफ़र की गई जानकारी की एक पंक्ति को पुनः प्राप्त करता है।

4

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

बफर से लाइनों की एक सरणी लेता है।

5

DBMS_OUTPUT.NEW_LINE;

एक अंत लाइन मार्कर डालता है।

6

DBMS_OUTPUT.PUT(item IN VARCHAR2);

बफर में एक आंशिक रेखा रखता है।

7

DBMS_OUTPUT.PUT_LINE(item IN VARCHAR2);

बफर में एक पंक्ति रखता है।

उदाहरण

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

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

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

PL/SQL procedure successfully completed.