PostgreSQL - कार्य

PostgreSQL functions, जिसे संग्रहीत कार्यविधियों के रूप में भी जाना जाता है, आपको उन ऑपरेशनों को करने की अनुमति देता है जो डेटाबेस के भीतर एक फ़ंक्शन में सामान्य रूप से कई प्रश्न और गोल यात्राएं करेंगे। फ़ंक्शंस डेटाबेस के पुन: उपयोग की अनुमति देते हैं क्योंकि अन्य अनुप्रयोग सीधे मध्य-स्तरीय या डुप्लिकेट कोड के बजाय आपके संग्रहीत कार्यविधियों के साथ सहभागिता कर सकते हैं।

अपनी पसंद की भाषा जैसे SQL, PL / pgSQL, C, Python, आदि में फंक्शंस बनाए जा सकते हैं।

वाक्य - विन्यास

फ़ंक्शन बनाने के लिए मूल सिंटैक्स निम्नानुसार है -

CREATE [OR REPLACE] FUNCTION function_name (arguments) 
RETURNS return_datatype AS $variable_name$
   DECLARE
      declaration;
      [...]
   BEGIN
      < function_body >
      [...]
      RETURN { variable_name | value }
   END; LANGUAGE plpgsql;

कहाँ पे,

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

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

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

  • RETURNखंड निर्दिष्ट करता है कि डेटा प्रकार आप फ़ंक्शन से वापस लौटने वाले हैं। return_datatype एक आधार, समग्र या डोमेन प्रकार हो सकता है, या एक तालिका स्तंभ के प्रकार को संदर्भित कर सकता है।

  • function-body निष्पादन योग्य भाग होता है।

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

  • plpgsqlउस भाषा का नाम है जिसे फ़ंक्शन कार्यान्वित किया गया है। यहां, हम PostgreSQL के लिए इस विकल्प का उपयोग करते हैं, यह SQL, C, आंतरिक या उपयोगकर्ता द्वारा परिभाषित प्रक्रियात्मक भाषा का नाम हो सकता है। पिछड़ी अनुकूलता के लिए, नाम को एकल उद्धरण द्वारा संलग्न किया जा सकता है।

उदाहरण

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

testdb# select * from COMPANY;
 id | name  | age | address   | salary
----+-------+-----+-----------+--------
  1 | Paul  |  32 | California|  20000
  2 | Allen |  25 | Texas     |  15000
  3 | Teddy |  23 | Norway    |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas     |  85000
  6 | Kim   |  22 | South-Hall|  45000
  7 | James |  24 | Houston   |  10000
(7 rows)

फंक्शन कुल रिकॉर्ड () इस प्रकार है -

CREATE OR REPLACE FUNCTION totalRecords ()
RETURNS integer AS $total$
declare
	total integer;
BEGIN
   SELECT count(*) into total FROM COMPANY;
   RETURN total;
END;
$total$ LANGUAGE plpgsql;

जब उपरोक्त क्वेरी निष्पादित की जाती है, तो परिणाम होगा -

testdb# CREATE FUNCTION

अब, इस फ़ंक्शन को कॉल निष्पादित करते हैं और कंपनी तालिका में रिकॉर्ड की जांच करते हैं

testdb=# select totalRecords();

जब उपरोक्त क्वेरी निष्पादित की जाती है, तो परिणाम होगा -

totalrecords
--------------
      7
(1 row)