PL / SQL - कार्य

इस अध्याय में, हम PL / SQL में कार्यों पर चर्चा करेंगे। एक फ़ंक्शन एक प्रक्रिया के समान है सिवाय इसके कि यह एक मूल्य लौटाता है। इसलिए, पिछले अध्याय की सभी चर्चाएँ कार्यों के लिए भी सही हैं।

एक फंक्शन बनाना

का उपयोग करके एक स्टैंडअलोन फ़ंक्शन बनाया जाता है CREATE FUNCTIONबयान। के लिए सरलीकृत वाक्यविन्यासCREATE OR REPLACE PROCEDURE कथन इस प्रकार है -

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

कहाँ पे,

  • function-name फ़ंक्शन का नाम निर्दिष्ट करता है।

  • [या रिपोर्ट] विकल्प एक मौजूदा फ़ंक्शन के संशोधन की अनुमति देता है।

  • वैकल्पिक पैरामीटर सूची में नाम, मोड और मापदंडों के प्रकार शामिल हैं। IN उस मूल्य का प्रतिनिधित्व करता है जो बाहर से पारित किया जाएगा और OUT उस पैरामीटर का प्रतिनिधित्व करता है जिसका उपयोग प्रक्रिया के बाहर एक मान लौटाने के लिए किया जाएगा।

  • फ़ंक्शन में एक होना चाहिए return बयान।

  • रिटर्न खंड डेटा टाइप आप समारोह से वापस जाने के लिए जा रहे हैं निर्दिष्ट करता है।

  • फ़ंक्शन-बॉडी में निष्पादन योग्य भाग होता है।

  • स्टैंडअलोन फ़ंक्शन बनाने के लिए IS कीवर्ड के बजाय AS कीवर्ड का उपयोग किया जाता है।

उदाहरण

निम्न उदाहरण दिखाता है कि कैसे एक स्टैंडअलोन फ़ंक्शन बनाने और कॉल करने के लिए। यह फ़ंक्शन ग्राहकों की तालिका में ग्राहकों की कुल संख्या लौटाता है।

हम कस्टमर्स टेबल का उपयोग करेंगे, जिसे हमने पीएल / एसक्यूएल वेरिएबल्स चैप्टर में बनाया था -

Select * from customers; 
 
+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

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

Function created.

एक समारोह बुला रहा है

एक फ़ंक्शन बनाते समय, आप एक परिभाषा देते हैं कि फ़ंक्शन को क्या करना है। फ़ंक्शन का उपयोग करने के लिए, आपको परिभाषित कार्य करने के लिए उस फ़ंक्शन को कॉल करना होगा। जब कोई प्रोग्राम किसी फ़ंक्शन को कॉल करता है, तो प्रोग्राम कंट्रोल को फ़ंक्शन में स्थानांतरित किया जाता है।

एक बुलाया फ़ंक्शन परिभाषित कार्य करता है और जब इसका रिटर्न स्टेटमेंट निष्पादित होता है या जब होता है last end statement पहुँच जाता है, यह प्रोग्राम नियंत्रण को मुख्य प्रोग्राम में वापस कर देता है।

किसी फ़ंक्शन को कॉल करने के लिए, आपको बस फ़ंक्शन नाम के साथ आवश्यक पैरामीटर पास करना होगा और यदि फ़ंक्शन एक मान लौटाता है, तो आप लौटाए गए मान को संग्रहीत कर सकते हैं। निम्नलिखित कार्यक्रम समारोह को बुलाता हैtotalCustomers एक अनाम ब्लॉक से -

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

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

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

उदाहरण

निम्न उदाहरण प्रदर्शन, परिभाषित, परिभाषित और एक साधारण पीएल / एसक्यूएल फ़ंक्शन को प्रदर्शित करता है जो अधिकतम दो मानों की गणना और रिटर्न करता है।

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

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

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

PL / SQL पुनरावर्ती कार्य

हमने देखा है कि एक प्रोग्राम या सबप्रोग्राम दूसरे सबप्रोग्राम कह सकता है। जब कोई उपप्रोग्राम स्वयं कॉल करता है, तो उसे पुनरावर्ती कॉल के रूप में संदर्भित किया जाता है और इस प्रक्रिया को इस रूप में जाना जाता हैrecursion

अवधारणा को स्पष्ट करने के लिए, आइए एक संख्या के भाज्य की गणना करें। संख्या n के गुणन को निम्न के रूप में परिभाषित किया गया है -

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

निम्नलिखित कार्यक्रम खुद को पुनरावर्ती कहकर किसी दिए गए संख्या के भाज्य की गणना करता है -

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

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

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.