PL / SQL - लेन-देन

इस अध्याय में, हम PL / SQL में लेनदेन पर चर्चा करेंगे। एक डेटाबेसtransactionकाम की एक परमाणु इकाई है जिसमें एक या अधिक संबंधित एसक्यूएल बयान शामिल हो सकते हैं। इसे परमाणु कहा जाता है क्योंकि SQL कथनों द्वारा लेन-देन का गठन करने वाले डेटाबेस संशोधनों को सामूहिक रूप से या तो प्रतिबद्ध किया जा सकता है, अर्थात डेटाबेस से स्थायी किया जाता है या डेटाबेस से वापस (पूर्ववत) किया जाता है।

सफलतापूर्वक निष्पादित SQL कथन और प्रतिबद्ध लेनदेन समान नहीं हैं। यहां तक ​​कि अगर किसी एसक्यूएल स्टेटमेंट को सफलतापूर्वक निष्पादित किया जाता है, जब तक कि स्टेटमेंट वाले लेन-देन को प्रतिबद्ध नहीं किया जाता है, तो इसे वापस रोल किया जा सकता है और स्टेटमेंट (एस) द्वारा किए गए सभी परिवर्तन पूर्ववत किए जा सकते हैं।

एक लेनदेन शुरू करना और समाप्त करना

एक लेन-देन एक है beginning और एक end। निम्नलिखित घटनाओं में से एक होने पर लेनदेन शुरू होता है -

  • पहले SQL स्टेटमेंट को डेटाबेस से कनेक्ट करने के बाद किया जाता है।

  • लेनदेन पूरा होने के बाद जारी किए गए प्रत्येक नए एसक्यूएल बयान में।

निम्नलिखित घटनाओं में से एक होने पर एक लेनदेन समाप्त होता है -

  • COMMIT या ए ROLLBACK बयान जारी किया गया है।

  • DDL कथन, जैसे CREATE TABLEबयान जारी किया गया है; क्योंकि उस स्थिति में एक कमिट स्वचालित रूप से किया जाता है।

  • DCL बयान, जैसे कि ए GRANTबयान जारी किया गया है; क्योंकि उस स्थिति में एक कमिट स्वचालित रूप से किया जाता है।

  • उपयोगकर्ता डेटाबेस से डिस्कनेक्ट करता है।

  • उपयोगकर्ता से बाहर निकलता है SQL*PLUS जारी करके EXIT कमांड, एक कमिट स्वचालित रूप से किया जाता है।

  • एसक्यूएल * प्लस असामान्य रूप से समाप्त होता है, ए ROLLBACK स्वचालित रूप से किया जाता है।

  • DMLबयान विफल; उस स्थिति में एक डीएमएल स्टेटमेंट को पूर्ववत करने के लिए एक रोलबैक स्वचालित रूप से किया जाता है।

लेन-देन करना

SQL कमांड COMMIT जारी करके लेनदेन को स्थायी किया जाता है। COMMIT कमांड का सामान्य सिंटैक्स है -

COMMIT;

उदाहरण के लिए,

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 ); 

COMMIT;

रोलिंग लेनदेन

COMMIT के बिना डेटाबेस में किए गए परिवर्तन ROLLBACK कमांड का उपयोग करके पूर्ववत किए जा सकते हैं।

रोलबैक कमांड का सामान्य सिंटैक्स है -

ROLLBACK [TO SAVEPOINT < savepoint_name>];

जब सिस्टम की विफलता जैसी किसी अभूतपूर्व स्थिति के कारण लेन-देन निरस्त कर दिया जाता है, तो एक प्रतिबद्ध होने के बाद से संपूर्ण लेन-देन स्वचालित रूप से वापस आ जाता है। यदि आप उपयोग नहीं कर रहे हैंsavepoint, उसके बाद सभी परिवर्तनों को रोलबैक करने के लिए बस निम्नलिखित कथन का उपयोग करें -

ROLLBACK;

Savepoints

सेवपॉइंट मार्करों की तरह होते हैं जो कुछ चौकियों को सेट करके छोटी इकाइयों में लंबे लेनदेन को विभाजित करने में मदद करते हैं। एक लंबे लेन-देन के भीतर सेवपॉइंट सेट करके, यदि आवश्यक हो, तो आप एक चेकपॉइंट पर वापस रोल कर सकते हैं। यह जारी करके किया जाता हैSAVEPOINT आदेश।

SAVEPOINT कमांड का सामान्य सिंटैक्स है -

SAVEPOINT < savepoint_name >;

उदाहरण के लिए

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Rajnish', 27, 'HP', 9500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (8, 'Riddhi', 21, 'WB', 4500.00 ); 
SAVEPOINT sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000; 
ROLLBACK TO sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 7; 
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 8; 

COMMIT;

ROLLBACK TO sav1 - यह कथन उस बिंदु तक सभी परिवर्तनों को वापस ले जाता है, जहां आपने savepoint sav1 को चिह्नित किया था।

उसके बाद, आपके द्वारा किए गए नए परिवर्तन शुरू हो जाएंगे।

स्वचालित लेनदेन नियंत्रण

निष्पादित करने के लिए COMMIT स्वचालित रूप से जब भी ए INSERT, UPDATE या DELETE कमांड निष्पादित किया जाता है, आप सेट कर सकते हैं AUTOCOMMIT पर्यावरण चर के रूप में -

SET AUTOCOMMIT ON;

आप निम्न कमांड का उपयोग करके ऑटो कमिट मोड को बंद कर सकते हैं -

SET AUTOCOMMIT OFF;