PL / SQL - ट्रिगर
इस अध्याय में, हम PL / SQL में ट्रिगर पर चर्चा करेंगे। ट्रिगर संग्रहीत प्रोग्राम हैं, जो कुछ घटनाओं के होने पर स्वचालित रूप से निष्पादित या निकाल दिए जाते हैं। ट्रिगर, वास्तव में, निम्न में से किसी भी घटना के जवाब में निष्पादित होने के लिए लिखे गए हैं -
ए database manipulation (DML) कथन (DELETE, INSERT, या अद्यतन)
ए database definition (DDL) कथन (सृजन, परिवर्तन, या ड्रॉप)।
ए database operation (सर्वर, लोगो, लोगो, STARTUP, या SHUTDOWN)।
ट्रिगर को टेबल, व्यू, स्कीमा या डेटाबेस से परिभाषित किया जा सकता है, जिसके साथ ईवेंट जुड़ा हुआ है।
ट्रिगर के लाभ
ट्रिगर को निम्नलिखित उद्देश्यों के लिए लिखा जा सकता है -
- स्वचालित रूप से कुछ व्युत्पन्न स्तंभ मान उत्पन्न करना
- संदर्भात्मक अखंडता को लागू करना
- टेबल प्रवेश पर सूचना लॉगिंग और भंडारण जानकारी
- Auditing
- तालिकाओं की तुल्यकालिक प्रतिकृति
- सुरक्षा प्राधिकरणों का निपटान
- अमान्य लेनदेन को रोकना
ट्रिगर बनाना
ट्रिगर बनाने का सिंटैक्स है -
CREATE [OR REPLACE ] TRIGGER trigger_name
{BEFORE | AFTER | INSTEAD OF }
{INSERT [OR] | UPDATE [OR] | DELETE}
[OF col_name]
ON table_name
[REFERENCING OLD AS o NEW AS n]
[FOR EACH ROW]
WHEN (condition)
DECLARE
Declaration-statements
BEGIN
Executable-statements
EXCEPTION
Exception-handling-statements
END;
कहाँ पे,
बनाएँ [या उत्तर] ट्रिगर ट्रिगर_नाम - एक मौजूदा ट्रिगर को ट्रिगर_नाम के साथ बनाता है या बदलता है ।
{पहले से | AFTER | INSTEAD OF} - यह तब निर्दिष्ट करता है जब ट्रिगर निष्पादित किया जाएगा। INSTEAD OF clause का उपयोग व्यू पर ट्रिगर बनाने के लिए किया जाता है।
{INSERT [OR] | अद्यतन [या] | DELETE} - यह DML ऑपरेशन को निर्दिष्ट करता है।
[Of col_name] - यह उस कॉलम नाम को निर्दिष्ट करता है जिसे अपडेट किया जाएगा।
[On table_name] - यह ट्रिगर से जुड़ी तालिका का नाम निर्दिष्ट करता है।
[REFERENCING OLD AS o NEW AS n] - यह आपको विभिन्न डीएमएल स्टेटमेंट्स जैसे कि INSERT, UPDATE और DELETE के लिए नए और पुराने मूल्यों को संदर्भित करने की अनुमति देता है।
[प्रत्येक पंक्ति के लिए] - यह एक पंक्ति-स्तरीय ट्रिगर निर्दिष्ट करता है, अर्थात, प्रत्येक पंक्ति को प्रभावित होने पर ट्रिगर निष्पादित किया जाएगा। अन्यथा SQL कथन निष्पादित होने पर ट्रिगर केवल एक बार निष्पादित होगा, जिसे टेबल स्तर ट्रिगर कहा जाता है।
WHEN (कंडीशन) - यह उन पंक्तियों के लिए एक शर्त प्रदान करता है जिसके लिए ट्रिगर आग होगा। यह क्लॉज केवल पंक्ति-स्तरीय ट्रिगर्स के लिए मान्य है।
उदाहरण
इसके साथ शुरू करने के लिए, हम पिछले तालिका में बनाए गए और उपयोग किए गए ग्राहक तालिका का उपयोग करेंगे -
Select * from customers;
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
+----+----------+-----+-----------+----------+
निम्नलिखित कार्यक्रम एक बनाता है row-levelउन ग्राहकों की तालिका के लिए ट्रिगर जो INSERT या UPDATE या DELETE संचालन के लिए आग करेंगे, जिन्होंने CUSTOMERS तालिका पर प्रदर्शन किया था। यह ट्रिगर पुराने मूल्यों और नए मूल्यों के बीच वेतन अंतर को प्रदर्शित करेगा -
CREATE OR REPLACE TRIGGER display_salary_changes
BEFORE DELETE OR INSERT OR UPDATE ON customers
FOR EACH ROW
WHEN (NEW.ID > 0)
DECLARE
sal_diff number;
BEGIN
sal_diff := :NEW.salary - :OLD.salary;
dbms_output.put_line('Old salary: ' || :OLD.salary);
dbms_output.put_line('New salary: ' || :NEW.salary);
dbms_output.put_line('Salary difference: ' || sal_diff);
END;
/
जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Trigger created.
निम्नलिखित बिंदुओं पर यहां विचार करने की आवश्यकता है -
ओएलडी और नए संदर्भ टेबल-स्तरीय ट्रिगर्स के लिए उपलब्ध नहीं हैं, बल्कि आप उन्हें रिकॉर्ड-लेवल ट्रिगर्स के लिए उपयोग कर सकते हैं।
यदि आप तालिका को उसी ट्रिगर में क्वेरी करना चाहते हैं, तो आपको AFTER कीवर्ड का उपयोग करना चाहिए, क्योंकि ट्रिगर तालिका को क्वेरी कर सकते हैं या प्रारंभिक परिवर्तन लागू होने के बाद ही इसे फिर से बदल सकते हैं और तालिका एक सुसंगत स्थिति में वापस आ जाती है।
उपरोक्त ट्रिगर को इस तरह से लिखा गया है कि यह टेबल पर किसी भी DELETE या INSERT या UPDATE ऑपरेशन से पहले फायर करेगा, लेकिन आप अपने ट्रिगर को एक या कई ऑपरेशनों पर लिख सकते हैं, उदाहरण के लिए BEFORE DELETE, जब भी रिकॉर्ड होगा तालिका पर DELETE कार्रवाई का उपयोग करके हटा दिया जाएगा।
ट्रिगर को ट्रिगर करना
चलिए CUSTOMERS टेबल पर कुछ DML ऑपरेशन करते हैं। यहाँ एक INSERT विवरण दिया गया है, जो तालिका में एक नया रिकॉर्ड बनाएगा -
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (7, 'Kriti', 22, 'HP', 7500.00 );
जब ग्राहक तालिका में एक रिकॉर्ड बनाया जाता है, तो उपरोक्त ट्रिगर बनाता है, display_salary_changes निकाल दिया जाएगा और यह निम्नलिखित परिणाम प्रदर्शित करेगा -
Old salary:
New salary: 7500
Salary difference:
क्योंकि यह एक नया रिकॉर्ड है, पुराना वेतन उपलब्ध नहीं है और उपरोक्त परिणाम शून्य है। अब हम CUSTOMERS टेबल पर एक और DML ऑपरेशन करते हैं। अद्यतन विवरण तालिका में मौजूदा रिकॉर्ड को अपडेट करेगा -
UPDATE customers
SET salary = salary + 500
WHERE id = 2;
जब एक रिकॉर्ड ग्राहक तालिका में अद्यतन किया जाता है, तो उपरोक्त ट्रिगर बनाता है, display_salary_changes निकाल दिया जाएगा और यह निम्नलिखित परिणाम प्रदर्शित करेगा -
Old salary: 1500
New salary: 2000
Salary difference: 500