PostgreSQL - परिवहन
लेनदेन एक कार्य की एक इकाई है जो एक डेटाबेस के खिलाफ किया जाता है। लेन-देन एक तार्किक क्रम में पूरी की जाने वाली इकाइयाँ या अनुक्रम हैं, चाहे वह उपयोगकर्ता द्वारा मैन्युअल रूप से या किसी प्रकार के डेटाबेस प्रोग्राम द्वारा स्वचालित रूप से हो।
एक लेनदेन डेटाबेस में एक या एक से अधिक परिवर्तनों का प्रसार है। उदाहरण के लिए, यदि आप एक रिकॉर्ड बना रहे हैं, रिकॉर्ड अपडेट कर रहे हैं या तालिका से रिकॉर्ड हटा रहे हैं, तो आप टेबल पर लेनदेन कर रहे हैं। डेटा अखंडता सुनिश्चित करने और डेटाबेस त्रुटियों को संभालने के लिए लेनदेन को नियंत्रित करना महत्वपूर्ण है।
व्यावहारिक रूप से, आप कई PostgreSQL प्रश्नों को एक समूह में क्लब करेंगे और आप एक लेनदेन के एक हिस्से के रूप में उन सभी को एक साथ निष्पादित करेंगे।
लेन-देन के गुण
लेन-देन में निम्नलिखित चार मानक गुण होते हैं, जिन्हें आमतौर पर संक्षिप्त ACID द्वारा संदर्भित किया जाता है -
Atomicity- यह सुनिश्चित करता है कि कार्य इकाई के भीतर सभी संचालन सफलतापूर्वक पूरा हो गए हैं; अन्यथा, विफलता के बिंदु पर लेन-देन समाप्त कर दिया जाता है और पिछले ऑपरेशनों को उनके पूर्व राज्य में वापस ले जाया जाता है।
Consistency - यह सुनिश्चित करता है कि डेटाबेस सफलतापूर्वक ठीक से किए गए लेन-देन पर परिवर्तन करता है।
Isolation - स्वतंत्र रूप से और एक दूसरे के लिए पारदर्शी संचालित करने के लिए लेनदेन को सक्षम करता है।
Durability - सुनिश्चित करता है कि प्रतिबद्ध लेनदेन का परिणाम या प्रभाव सिस्टम की विफलता के मामले में बना रहता है।
लेन-देन नियंत्रण
लेन-देन को नियंत्रित करने के लिए निम्न आदेशों का उपयोग किया जाता है -
BEGIN TRANSACTION - लेन-देन शुरू करना।
COMMIT - परिवर्तनों को सहेजने के लिए, वैकल्पिक रूप से आप उपयोग कर सकते हैं END TRANSACTION आदेश।
ROLLBACK - परिवर्तनों को रोलबैक करने के लिए।
लेन-देन नियंत्रण आदेश केवल DML कमांड INSERT, UPDATE और DELETE के साथ ही उपयोग किए जाते हैं। इनका उपयोग तालिकाओं को बनाते समय या उन्हें गिराते समय नहीं किया जा सकता क्योंकि ये ऑपरेशन डेटाबेस में स्वचालित रूप से किए जाते हैं।
बेगिन परिवहन आदेश
लेन-देन BEGIN परिवहन या बस BEGIN आदेश का उपयोग करके शुरू किया जा सकता है। इस तरह के लेनदेन आमतौर पर तब तक बने रहते हैं जब तक कि अगले COMMIT या ROLLBACK कमांड का सामना नहीं हो जाता। लेकिन डेटाबेस बंद होने पर या यदि कोई त्रुटि होती है, तो लेन-देन भी रोलबैक होगा।
लेनदेन शुरू करने के लिए सरल वाक्यविन्यास निम्नलिखित है -
BEGIN;
or
BEGIN TRANSACTION;
COMMIT कमांड
COMMIT कमांड एक ट्रांसेक्शनल कमांड है जिसका उपयोग डेटाबेस में ट्रांजेक्शन के लिए किए गए परिवर्तनों को बचाने के लिए किया जाता है।
COMMIT कमांड अंतिम COMMIT या ROLLBACK कमांड के बाद से डेटाबेस के लिए सभी लेनदेन बचाता है।
COMMIT कमांड का सिंटैक्स इस प्रकार है -
COMMIT;
or
END TRANSACTION;
रोल कमांड
रोलबैक कमांड लेनदेन को पूर्ववत करने के लिए उपयोग किया जाने वाला ट्रांसेक्शनल कमांड है जिसे पहले से डेटाबेस में सहेजा नहीं गया है।
ROLLBACK कमांड का उपयोग केवल पिछले COMMIT या ROLLBACK कमांड जारी होने के बाद लेनदेन को पूर्ववत करने के लिए किया जा सकता है।
रोलबैक कमांड का सिंटैक्स इस प्रकार है -
ROLLBACK;
उदाहरण
कंपनी तालिका पर विचार करें निम्नलिखित रिकॉर्ड है -
id | name | age | address | salary
----+-------+-----+-----------+--------
1 | Paul | 32 | California| 20000
2 | Allen | 25 | Texas | 15000
3 | Teddy | 23 | Norway | 20000
4 | Mark | 25 | Rich-Mond | 65000
5 | David | 27 | Texas | 85000
6 | Kim | 22 | South-Hall| 45000
7 | James | 24 | Houston | 10000
अब, एक लेनदेन शुरू करते हैं और 25 = आयु होने वाली तालिका से रिकॉर्ड हटाते हैं और अंत में हम सभी परिवर्तनों को पूर्ववत् करने के लिए रोलबैक कमांड का उपयोग करते हैं।
testdb=# BEGIN;
DELETE FROM COMPANY WHERE AGE = 25;
ROLLBACK;
यदि आप जाँचेंगे कि कंपनी की तालिका में अभी भी निम्नलिखित रिकॉर्ड हैं -
id | name | age | address | salary
----+-------+-----+-----------+--------
1 | Paul | 32 | California| 20000
2 | Allen | 25 | Texas | 15000
3 | Teddy | 23 | Norway | 20000
4 | Mark | 25 | Rich-Mond | 65000
5 | David | 27 | Texas | 85000
6 | Kim | 22 | South-Hall| 45000
7 | James | 24 | Houston | 10000
अब, आइए हम एक और लेन-देन शुरू करते हैं और उम्र = 25 होने वाली तालिका से रिकॉर्ड हटाते हैं और अंत में हम सभी परिवर्तनों को करने के लिए COMMIT कमांड का उपयोग करते हैं।
testdb=# BEGIN;
DELETE FROM COMPANY WHERE AGE = 25;
COMMIT;
यदि आप कंपनी तालिका की जाँच करेंगे, तो यह अभी भी निम्नलिखित रिकॉर्ड है -
id | name | age | address | salary
----+-------+-----+------------+--------
1 | Paul | 32 | California | 20000
3 | Teddy | 23 | Norway | 20000
5 | David | 27 | Texas | 85000
6 | Kim | 22 | South-Hall | 45000
7 | James | 24 | Houston | 10000
(5 rows)