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;