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;