PostgreSQL - ट्रिगर्स

PostgreSQL Triggers डेटाबेस कॉलबैक फ़ंक्शन हैं, जो एक निर्दिष्ट डेटाबेस ईवेंट होने पर स्वचालित रूप से निष्पादित / इनवॉइस किए जाते हैं।

PostgreSQL ट्रिगर के बारे में निम्नलिखित महत्वपूर्ण बिंदु हैं -

  • PostgreSQL ट्रिगर को आग में निर्दिष्ट किया जा सकता है

    • एक पंक्ति पर कार्रवाई का प्रयास करने से पहले (बाधाओं की जाँच करने से पहले और INSERT, UPDATE या DELETE का प्रयास किया जाता है)

    • ऑपरेशन पूरा होने के बाद (बाधाओं की जाँच होने के बाद और INSERT, UPDATE, या DELETE पूरा हो गया है)

    • ऑपरेशन के बजाय (आवेषण के मामले में, किसी दृश्य पर अपडेट या डिलीट)

  • एक ट्रिगर जिसे EACH ROW के लिए चिह्नित किया जाता है, ऑपरेशन को संशोधित करने वाली प्रत्येक पंक्ति के लिए एक बार कहा जाता है। इसके विपरीत, एक ट्रिगर जिसे EACH STATEMENT के लिए चिह्नित किया गया है, यह किसी भी दिए गए ऑपरेशन के लिए केवल एक बार निष्पादित होता है, चाहे वह कितनी भी पंक्तियों को संशोधित करता हो।

  • दोनों, जब खंड और ट्रिगर क्रिया, पंक्ति के तत्वों को सम्मिलित कर सकते हैं, प्रपत्र के संदर्भों का उपयोग करके हटाए या अपडेट किए जा सकते हैं NEW.column-name तथा OLD.column-name, जहां स्तंभ-नाम उस तालिका से स्तंभ का नाम है जिससे ट्रिगर जुड़ा हुआ है।

  • यदि WHEN क्लॉज की आपूर्ति की जाती है, तो निर्दिष्ट PostgreSQL बयान केवल उन पंक्तियों के लिए निष्पादित किए जाते हैं जिनके लिए WHEN क्लॉज सत्य है। यदि कोई क्लेंज़ नहीं दिया जाता है, तो PostgreSQL स्टेटमेंट्स को सभी पंक्तियों के लिए निष्पादित किया जाता है।

  • यदि एक ही तरह के कई ट्रिगर्स एक ही घटना के लिए परिभाषित किए जाते हैं, तो उन्हें नाम से वर्णानुक्रम में निकाल दिया जाएगा।

  • कीवर्ड के पहले, पहले या इंसटैड का निर्धारण तब होता है जब ट्रिगर क्रियाओं को संबंधित पंक्ति के सम्मिलन, संशोधन या हटाने के सापेक्ष निष्पादित किया जाएगा।

  • ट्रिगर स्वचालित रूप से गिरा दिया जाता है जब वह जिस तालिका से जुड़ा होता है उसे गिरा दिया जाता है।

  • संशोधित की जाने वाली तालिका उसी डेटाबेस में मौजूद होनी चाहिए जिस तालिका या दृश्य में ट्रिगर जुड़ा हुआ है और किसी को बस उपयोग करना होगा tablename, नहीं database.tablename

  • निर्दिष्ट होने पर एक कसना विकल्प एक अवरोध पैदा करता है । यह एक नियमित ट्रिगर के समान है सिवाय इसके कि ट्रिगर फायरिंग के समय को SET CONSTRAINTS का उपयोग करके समायोजित किया जा सकता है। बाधा ट्रिगर से एक अपवाद को बढ़ाने की उम्मीद की जाती है जब वे लागू होने वाली बाधाओं का उल्लंघन किया जाता है।

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

एक बनाने का मूल वाक्यविन्यास trigger इस प्रकार है -

CREATE  TRIGGER trigger_name [BEFORE|AFTER|INSTEAD OF] event_name
ON table_name
[
 -- Trigger logic goes here....
];

यहाँ, event_nameउल्लेख तालिका पर INSERT, DELETE, UPDATE और TRUNCATE डेटाबेस ऑपरेशन हो सकता हैtable_name। आप वैकल्पिक रूप से तालिका के नाम के बाद प्रत्येक के लिए निर्दिष्ट कर सकते हैं।

निम्न तालिका के एक या एक से अधिक निर्दिष्ट स्तंभों पर एक अद्यतन पर ट्रिगर बनाने का सिंटैक्स निम्न है: -

CREATE  TRIGGER trigger_name [BEFORE|AFTER] UPDATE OF column_name
ON table_name
[
 -- Trigger logic goes here....
];

उदाहरण

आइए एक ऐसे मामले पर विचार करें, जहां हम कंपनी के टेबल में डाले जा रहे हर रिकॉर्ड के लिए ऑडिट ट्रायल रखना चाहते हैं, जिसे हम इस प्रकार बनाएंगे (ड्रॉप कंपनी टेबल यदि आपके पास पहले से है)।

testdb=# CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

ऑडिट ट्रायल रखने के लिए, हम AUDIT नाम से एक नई तालिका बनाएंगे जहाँ लॉग संदेश डाले जाएँगे जब भी किसी नए रिकॉर्ड के लिए कंपनी तालिका में कोई प्रविष्टि होगी -

testdb=# CREATE TABLE AUDIT(
   EMP_ID INT NOT NULL,
   ENTRY_DATE TEXT NOT NULL
);

यहां, आईडी AUDIT रिकॉर्ड आईडी है, और EMP_ID आईडी है, जो कंपनी तालिका से आएगी, और DATE टाइमस्टैम्प तब रखेगी जब रिकॉर्ड कंपनी तालिका में बनाया जाएगा। तो अब, हम निम्नानुसार कंपनी की मेज पर एक ट्रिगर बनाते हैं -

testdb=# CREATE TRIGGER example_trigger AFTER INSERT ON COMPANY
FOR EACH ROW EXECUTE PROCEDURE auditlogfunc();

जहां Audloglogfunc () एक PostgreSQL है procedure और इसकी निम्न परिभाषा है -

CREATE OR REPLACE FUNCTION auditlogfunc() RETURNS TRIGGER AS $example_table$
   BEGIN
      INSERT INTO AUDIT(EMP_ID, ENTRY_DATE) VALUES (new.ID, current_timestamp);
      RETURN NEW;
   END;
$example_table$ LANGUAGE plpgsql;

अब, हम वास्तविक काम शुरू करेंगे। हमें कंपनी तालिका में रिकॉर्ड सम्मिलित करना शुरू करना चाहिए जिसके परिणामस्वरूप AUDIT तालिका में ऑडिट लॉग रिकॉर्ड बनाना चाहिए। तो आइए हम कंपनी तालिका में एक रिकॉर्ड बनाते हैं -

testdb=# INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 );

यह कंपनी तालिका में एक रिकॉर्ड बनाएगी, जो इस प्रकार है -

id | name | age | address      | salary
----+------+-----+--------------+--------
  1 | Paul |  32 | California   |  20000

उसी समय, एक रिकॉर्ड AUDIT तालिका में बनाया जाएगा। यह रिकॉर्ड एक ट्रिगर का परिणाम है, जिसे हमने कंपनी टेबल पर INSERT ऑपरेशन पर बनाया है। इसी तरह, आप अपनी आवश्यकताओं के आधार पर अपने ट्रिगर को अपडेट और डिलीट कर सकते हैं।

emp_id |          entry_date
--------+-------------------------------
      1 | 2013-05-05 15:49:59.968+05:30
(1 row)

सूचीबद्ध ट्रिगर्स

आप वर्तमान डेटाबेस से सभी ट्रिगर को नीचे सूचीबद्ध कर सकते हैं pg_trigger तालिका निम्नानुसार है -

testdb=# SELECT * FROM pg_trigger;

ऊपर दिया गया PostgreSQL स्टेटमेंट सभी ट्रिगर को नीचे सूचीबद्ध करेगा।

यदि आप किसी विशेष टेबल पर ट्रिगर्स को सूचीबद्ध करना चाहते हैं, तो निम्नानुसार तालिका नाम के साथ AND क्लॉज़ का उपयोग करें -

testdb=# SELECT tgname FROM pg_trigger, pg_class WHERE tgrelid=pg_class.oid AND relname='company';

ऊपर दिए गए PostgreSQL स्टेटमेंट में केवल एक प्रविष्टि को निम्नानुसार सूचीबद्ध किया जाएगा -

tgname
-----------------
 example_trigger
(1 row)

छोड़ने वाले ट्रिगर्स

निम्नलिखित DROP कमांड है, जिसका उपयोग मौजूदा ट्रिगर को गिराने के लिए किया जा सकता है -

testdb=# DROP TRIGGER trigger_name;