PL / SQL - मूल सिंटैक्स

इस अध्याय में, हम PL / SQL के मूल सिंटैक्स की चर्चा करेंगे जो कि ए block-structuredभाषा: हिन्दी; इसका अर्थ है कि PL / SQL प्रोग्राम कोड के तार्किक ब्लॉकों में विभाजित और लिखे गए हैं। प्रत्येक ब्लॉक में तीन उप-भाग होते हैं -

S.No अनुभाग और विवरण
1

Declarations

यह खंड कीवर्ड से शुरू होता है DECLARE। यह एक वैकल्पिक अनुभाग है और कार्यक्रम में उपयोग किए जाने वाले सभी चर, कर्सर, उपप्रोग्राम और अन्य तत्वों को परिभाषित करता है।

2

Executable Commands

यह खंड खोजशब्दों के बीच संलग्न है BEGIN तथा ENDऔर यह एक अनिवार्य अनुभाग है। यह प्रोग्राम के निष्पादन योग्य PL / SQL कथनों से युक्त होता है। इसमें कोड की कम से कम एक निष्पादन योग्य रेखा होनी चाहिए, जो सिर्फ एक हो सकती हैNULL command यह इंगित करने के लिए कि कुछ भी निष्पादित नहीं किया जाना चाहिए।

3

Exception Handling

यह खंड कीवर्ड से शुरू होता है EXCEPTION। इस वैकल्पिक अनुभाग में शामिल हैexception(s) कि कार्यक्रम में त्रुटियों को संभाल।

प्रत्येक पीएल / एसक्यूएल स्टेटमेंट एक अर्धविराम (;) के साथ समाप्त होता है। PL / SQL ब्लॉक का उपयोग करके अन्य PL / SQL ब्लॉक के भीतर नेस्टेड किया जा सकता हैBEGIN तथा END। निम्नलिखित PL / SQL ब्लॉक की मूल संरचना है -

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)>
EXCEPTION 
   <exception handling> 
END;

'हैलो वर्ल्ड' उदाहरण

DECLARE 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/

end;पीएल / एसक्यूएल ब्लॉक के अंत में लाइन सिग्नल। SQL कमांड लाइन से कोड को चलाने के लिए, आपको कोड की अंतिम पंक्ति के बाद पहली रिक्त लाइन की शुरुआत में टाइप करना होगा। जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Hello World  

PL/SQL procedure successfully completed.

PL / SQL पहचानकर्ता

PL / SQL पहचानकर्ता स्थिरांक, चर, अपवाद, प्रक्रियाएं, शापदाता और आरक्षित शब्द हैं। पहचानकर्ताओं में एक अक्षर होता है जिसमें वैकल्पिक रूप से अधिक अक्षर, अंक, डॉलर चिह्न, अंडरस्कोर और संख्या चिह्न होते हैं और यह 30 वर्णों से अधिक नहीं होना चाहिए।

डिफ़ॉल्ट रूप से, identifiers are not case-sensitive। तो आप उपयोग कर सकते हैंinteger या INTEGERएक संख्यात्मक मान का प्रतिनिधित्व करने के लिए। आप पहचानकर्ता के रूप में आरक्षित कीवर्ड का उपयोग नहीं कर सकते।

पीएल / एसक्यूएल डेलीमीटर

एक सीमांकक एक विशेष अर्थ के साथ एक प्रतीक है। निम्नलिखित PL / SQL में सीमांकक की सूची है -

सीमान्तक विवरण
+, -, *, / जोड़, घटाव / निषेध, गुणा, भाग
% संकेतक का प्रतिनिधित्व करें
' चरित्र स्ट्रिंग सीमांकक
. घटक चयनकर्ता
(,) अभिव्यक्ति या सूची परिसीमन
: मेजबान चर संकेतक
, आइटम विभाजक
" उद्धृत पहचानकर्ता परिसीमन
= संबंधित ऑपरेटर
@ रिमोट एक्सेस इंडिकेटर
; कथन टर्मिनेटर
:= असाइनमेंट ऑपरेटर
=> संघ संचालक
|| सांत्वना देनेवाला संचालक
** यययय ययय ययय यययय यय
<<, >> लेबल परिसीमन (आरंभ और अंत)
/*, */ बहु-पंक्ति टिप्पणी परिसीमन (आरंभ और अंत)
-- एकल-पंक्ति टिप्पणी संकेतक
.. रेंज ऑपरेटर
<, >, <=, >= संबंधपरक संकारक
<>, '=, ~=, ^= अलग-अलग संस्करण नहीं

PL / SQL टिप्पणियाँ

कार्यक्रम की टिप्पणियां व्याख्यात्मक वक्तव्य हैं जिन्हें पीएल / एसक्यूएल कोड में शामिल किया जा सकता है जो आप लिखते हैं और किसी को इसके स्रोत कोड को पढ़ने में मदद करते हैं। सभी प्रोग्रामिंग भाषाएं किसी न किसी रूप में टिप्पणियों की अनुमति देती हैं।

PL / SQL सिंगल-लाइन और मल्टी-लाइन टिप्पणियों का समर्थन करता है। किसी भी टिप्पणी के अंदर उपलब्ध सभी पात्रों को पीएल / एसक्यूएल संकलक द्वारा अनदेखा किया जाता है। पीएल / एसक्यूएल सिंगल-लाइन टिप्पणियां सीमांकक के साथ शुरू होती हैं - (डबल हाइफ़न) और मल्टी-लाइन टिप्पणियां / * और * / द्वारा संलग्न हैं।

DECLARE 
   -- variable declaration 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   /* 
   *  PL/SQL executable statement(s) 
   */ 
   dbms_output.put_line(message); 
END; 
/

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

Hello World

PL/SQL procedure successfully completed.

PL / SQL प्रोग्राम इकाइयाँ

PL / SQL यूनिट निम्नलिखित में से कोई एक है -

  • PL / SQL ब्लॉक
  • Function
  • Package
  • पैकेज बॉडी
  • Procedure
  • Trigger
  • Type
  • बॉडी टाइप करें

इनमें से प्रत्येक इकाई पर निम्नलिखित अध्यायों में चर्चा की जाएगी।