SQLite - ट्रिगर

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

  • जब भी किसी विशेष डेटाबेस तालिका का DELETE, INSERT या UPDATE होता है या जब भी एक तालिका के एक या अधिक निर्दिष्ट स्तंभों पर UPDATE होता है, तो SQLite ट्रिगर को निर्दिष्ट किया जा सकता है।

  • इस समय, SQLite केवल EOW ROW ट्रिगर्स के लिए समर्थन करता है, EACH STATEMENT ट्रिगर्स के लिए नहीं। इसलिए, EACH ROW के लिए स्पष्ट रूप से निर्दिष्ट करना वैकल्पिक है।

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

  • यदि WHEN क्लॉज की आपूर्ति की जाती है, तो निर्दिष्ट SQL कथन केवल उन पंक्तियों के लिए निष्पादित किए जाते हैं जिनके लिए WHEN क्लॉज सत्य है। यदि कोई खंड नहीं दिया गया है, तो SQL कथन सभी पंक्तियों के लिए निष्पादित किए जाते हैं।

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

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

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

  • अपवाद को बढ़ाने के लिए एक विशेष SQL फ़ंक्शन RAISE () का उपयोग ट्रिगर-प्रोग्राम के भीतर किया जा सकता है।

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

निम्नलिखित एक बनाने का मूल वाक्यविन्यास है trigger

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

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

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

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

उदाहरण

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

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

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

sqlite> CREATE TABLE AUDIT(
   EMP_ID INT NOT NULL,
   ENTRY_DATE TEXT NOT NULL
);

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

sqlite> CREATE TRIGGER audit_log AFTER INSERT 
ON COMPANY
BEGIN
   INSERT INTO AUDIT(EMP_ID, ENTRY_DATE) VALUES (new.ID, datetime('now'));
END;

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

sqlite> 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.0

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

EMP_ID      ENTRY_DATE
----------  -------------------
1           2013-04-05 06:26:00

लिस्टिंग ट्रिगर

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

sqlite> SELECT name FROM sqlite_master
WHERE type = 'trigger';

उपरोक्त SQLite बयान केवल एक प्रविष्टि को नीचे सूचीबद्ध करेगा -

name
----------
audit_log

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

sqlite> SELECT name FROM sqlite_master
WHERE type = 'trigger' AND tbl_name = 'COMPANY';

उपरोक्त SQLite बयान भी केवल एक प्रविष्टि को निम्नानुसार सूचीबद्ध करेगा -

name
----------
audit_log

ट्रिगर्स को गिरा देना

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

sqlite> DROP TRIGGER trigger_name;