पीएल / एसक्यूएल - चर

इस अध्याय में, हम Pl / SQL में चर की चर्चा करेंगे। एक चर कुछ भी नहीं है लेकिन एक भंडारण क्षेत्र को दिया गया नाम है जो हमारे कार्यक्रमों में हेरफेर कर सकता है। पीएल / एसक्यूएल में प्रत्येक चर में एक विशिष्ट डेटा प्रकार होता है, जो चर की स्मृति के आकार और लेआउट को निर्धारित करता है; मानों की वह सीमा जो उस मेमोरी के भीतर संग्रहीत की जा सकती है और परिचालनों पर लागू होने वाले संचालन का सेट।

पीएल / एसक्यूएल वैरिएबल के नाम में एक अक्षर होता है, जिसके बाद वैकल्पिक रूप से अधिक अक्षर, अंक, डॉलर चिह्न, अंडरस्कोर और संख्या चिन्ह होते हैं और यह 30 अक्षरों से अधिक नहीं होना चाहिए। डिफ़ॉल्ट रूप से, चर नाम केस-संवेदी नहीं होते हैं। आप एक चर नाम के रूप में आरक्षित PL / SQL कीवर्ड का उपयोग नहीं कर सकते।

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

PL / SQL में चर घोषणा

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

एक चर घोषित करने के लिए वाक्य रचना है -

variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]

जहां, variable_name PL / SQL में एक मान्य पहचानकर्ता है, डेटाटाइप एक मान्य PL / SQL डेटा प्रकार या कोई भी उपयोगकर्ता परिभाषित डेटा प्रकार होना चाहिए , जिसकी हमने पहले ही अंतिम अध्याय में चर्चा की है। उनकी परिभाषा के साथ कुछ मान्य परिवर्तनीय घोषणाएँ नीचे दी गई हैं -

sales number(10, 2); 
pi CONSTANT double precision := 3.1415; 
name varchar2(25); 
address varchar2(100);

जब आप डेटा प्रकार के साथ एक आकार, पैमाने या सटीक सीमा प्रदान करते हैं, तो इसे कहा जाता है constrained declaration। असंबंधित घोषणाओं को असंवैधानिक घोषणाओं की तुलना में कम स्मृति की आवश्यकता होती है। उदाहरण के लिए -

sales number(10, 2); 
name varchar2(25); 
address varchar2(100);

PL / SQL में वैरिएबल को आरम्भ करना

जब भी आप एक चर घोषित करते हैं, PL / SQL इसे NULL का डिफ़ॉल्ट मान प्रदान करता है। यदि आप NULL वैल्यू के अलावा किसी वैरिएबल को इनिशियलाइज़ करना चाहते हैं, तो आप घोषणा के दौरान ऐसा कर सकते हैं, निम्न में से किसी एक का उपयोग करके -

  • DEFAULT कीवर्ड

  • assignment ऑपरेटर

उदाहरण के लिए -

counter binary_integer := 0; 
greetings varchar2(20) DEFAULT 'Have a Good Day';

आप यह भी निर्दिष्ट कर सकते हैं कि एक चर में ए नहीं होना चाहिए NULL का उपयोग कर मूल्य NOT NULLबाधा। यदि आप NOT NULL बाधा का उपयोग करते हैं, तो आपको उस चर के लिए प्रारंभिक मूल्य स्पष्ट रूप से निर्दिष्ट करना होगा।

यह एक अच्छा प्रोग्रामिंग अभ्यास है कि चर को ठीक से प्रारंभ करें अन्यथा, कभी-कभी प्रोग्राम अप्रत्याशित परिणाम उत्पन्न करते हैं। निम्नलिखित उदाहरण का प्रयास करें जो विभिन्न प्रकार के चर का उपयोग करता है -

DECLARE 
   a integer := 10; 
   b integer := 20; 
   c integer; 
   f real; 
BEGIN 
   c := a + b; 
   dbms_output.put_line('Value of c: ' || c); 
   f := 70.0/3.0; 
   dbms_output.put_line('Value of f: ' || f); 
END; 
/

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

Value of c: 30 
Value of f: 23.333333333333333333  

PL/SQL procedure successfully completed.

PL / SQL में चर स्कोप

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

  • Local variables - एक आंतरिक ब्लॉक में घोषित चर और बाहरी ब्लॉकों तक पहुंच योग्य नहीं है।

  • Global variables - सबसे बाहरी ब्लॉक या पैकेज में घोषित चर।

निम्नलिखित उदाहरण के उपयोग से पता चलता है Local तथा Global इसके सरल रूप में चर -

DECLARE 
   -- Global variables  
   num1 number := 95;  
   num2 number := 85;  
BEGIN  
   dbms_output.put_line('Outer Variable num1: ' || num1); 
   dbms_output.put_line('Outer Variable num2: ' || num2); 
   DECLARE  
      -- Local variables 
      num1 number := 195;  
      num2 number := 185;  
   BEGIN  
      dbms_output.put_line('Inner Variable num1: ' || num1); 
      dbms_output.put_line('Inner Variable num2: ' || num2); 
   END;  
END; 
/

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

Outer Variable num1: 95 
Outer Variable num2: 85 
Inner Variable num1: 195 
Inner Variable num2: 185  

PL/SQL procedure successfully completed.

पीएल / एसक्यूएल चर के लिए SQL क्वेरी परिणाम निरुपित

आप उपयोग कर सकते हैं SELECT INTOपीएल / एसक्यूएल चर को मान असाइन करने के लिए एसक्यूएल का विवरण। में प्रत्येक आइटम के लिएSELECT list, इसमें एक संगत, प्रकार-संगत चर होना चाहिए INTO list। निम्नलिखित उदाहरण अवधारणा को दर्शाता है। हमें CUSTOMERS नाम की एक तालिका बनाएँ -

(For SQL statements, please refer to the SQL tutorial)

CREATE TABLE CUSTOMERS( 
   ID   INT NOT NULL, 
   NAME VARCHAR (20) NOT NULL, 
   AGE INT NOT NULL, 
   ADDRESS CHAR (25), 
   SALARY   DECIMAL (18, 2),        
   PRIMARY KEY (ID) 
);  

Table Created

आइये अब टेबल में कुछ मान डालें -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
  
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 
 
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 );

निम्न प्रोग्राम उपरोक्त तालिका से PL / SQL चर का उपयोग करके मान प्रदान करता है SELECT INTO clause SQL का -

DECLARE 
   c_id customers.id%type := 1; 
   c_name  customers.name%type; 
   c_addr customers.address%type; 
   c_sal  customers.salary%type; 
BEGIN 
   SELECT name, address, salary INTO c_name, c_addr, c_sal 
   FROM customers 
   WHERE id = c_id;  
   dbms_output.put_line 
   ('Customer ' ||c_name || ' from ' || c_addr || ' earns ' || c_sal); 
END; 
/

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

Customer Ramesh from Ahmedabad earns 2000  

PL/SQL procedure completed successfully