SQLite - लेनदेन
लेनदेन एक कार्य की एक इकाई है जो एक डेटाबेस के खिलाफ किया जाता है। लेन-देन एक तार्किक क्रम में पूरी की जाने वाली इकाइयाँ या अनुक्रम हैं, चाहे वह उपयोगकर्ता द्वारा मैन्युअल रूप से या किसी प्रकार के डेटाबेस प्रोग्राम द्वारा स्वचालित रूप से हो।
एक लेनदेन डेटाबेस में एक या एक से अधिक परिवर्तनों का प्रसार है। उदाहरण के लिए, यदि आप तालिका से रिकॉर्ड बना रहे हैं, अपडेट कर रहे हैं या हटा रहे हैं, तो आप टेबल पर लेनदेन कर रहे हैं। डेटा अखंडता सुनिश्चित करने और डेटाबेस त्रुटियों को संभालने के लिए लेनदेन को नियंत्रित करना महत्वपूर्ण है।
व्यावहारिक रूप से, आप एक समूह में कई SQLite प्रश्नों को क्लब करेंगे और आप लेनदेन के हिस्से के रूप में उन सभी को एक साथ निष्पादित करेंगे।
लेन-देन के गुण
लेन-देन में निम्नलिखित चार मानक गुण होते हैं, जिन्हें आमतौर पर संक्षिप्त ACID द्वारा संदर्भित किया जाता है।
Atomicity- यह सुनिश्चित करता है कि कार्य इकाई के भीतर सभी संचालन सफलतापूर्वक पूरा हो गए हैं; अन्यथा, विफलता के बिंदु पर लेन-देन समाप्त कर दिया जाता है और पिछले ऑपरेशनों को उनके पूर्व राज्य में वापस ले जाया जाता है।
Consistency - यह सुनिश्चित करता है कि डेटाबेस सफलतापूर्वक ठीक से किए गए लेन-देन पर परिवर्तन करता है।
Isolation - स्वतंत्र रूप से और एक दूसरे के लिए पारदर्शी संचालित करने के लिए लेनदेन को सक्षम करता है।
Durability - सुनिश्चित करता है कि प्रतिबद्ध लेनदेन का परिणाम या प्रभाव सिस्टम की विफलता के मामले में बना रहता है।
लेन-देन नियंत्रण
लेनदेन को नियंत्रित करने के लिए निम्नलिखित आदेश दिए गए हैं:
BEGIN TRANSACTION - लेन-देन शुरू करना।
COMMIT - परिवर्तनों को सहेजने के लिए, वैकल्पिक रूप से आप उपयोग कर सकते हैं END TRANSACTION आदेश।
ROLLBACK - परिवर्तनों को रोलबैक करने के लिए।
लेन-देन नियंत्रण आदेश केवल DML कमांड INSERT, UPDATE और DELETE के साथ उपयोग किए जाते हैं। इनका उपयोग तालिकाओं को बनाते समय या उन्हें गिराते समय नहीं किया जा सकता क्योंकि ये ऑपरेशन डेटाबेस में स्वचालित रूप से किए जाते हैं।
BEGIN परिवहन कमान
लेन-देन BEGIN परिवहन या बस BEGIN आदेश का उपयोग करके शुरू किया जा सकता है। इस तरह के लेनदेन आमतौर पर तब तक बने रहते हैं जब तक कि अगले COMMIT या ROLLBACK कमांड का सामना नहीं हो जाता। हालाँकि, डेटाबेस बंद है या यदि कोई त्रुटि होती है, तो लेन-देन भी रोलबैक होगा। लेन-देन शुरू करने के लिए सरल वाक्यविन्यास निम्नलिखित है।
BEGIN;
or
BEGIN TRANSACTION;
COMMIT कमांड
COMMIT कमांड एक ट्रांसेक्शनल कमांड है जिसका इस्तेमाल डेटाबेस में ट्रांजेक्शन के लिए किए गए परिवर्तनों को बचाने के लिए किया जाता है।
COMMIT कमांड अंतिम COMMIT या ROLLBACK कमांड के बाद से डेटाबेस के सभी लेन-देन को बचाता है।
निम्नलिखित COMMIT कमांड के लिए सिंटैक्स है।
COMMIT;
or
END TRANSACTION;
रोलबैक कमांड
रोलबैक आदेश लेनदेन को पूर्ववत करने के लिए उपयोग किया जाने वाला ट्रांसेक्शनल कमांड है जो पहले से ही डेटाबेस में सहेजा नहीं गया है।
ROLLBACK कमांड केवल पिछले COMMIT या ROLLBACK कमांड जारी होने के बाद लेनदेन को पूर्ववत करने के लिए उपयोग किया जा सकता है।
निम्नलिखित ROLLBACK कमांड के लिए सिंटैक्स है।
ROLLBACK;
Example
निम्नलिखित रिकॉर्ड के साथ कंपनी की तालिका पर विचार करें ।
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
अब, एक लेनदेन शुरू करते हैं और उम्र = 25 होने वाली तालिका से रिकॉर्ड हटाते हैं। फिर, सभी परिवर्तनों को पूर्ववत् करने के लिए रोलबैक कमांड का उपयोग करें।
sqlite> BEGIN;
sqlite> DELETE FROM COMPANY WHERE AGE = 25;
sqlite> ROLLBACK;
अब, यदि आप कंपनी तालिका की जाँच करते हैं, तो यह अभी भी निम्नलिखित रिकॉर्ड है -
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
आइए एक और लेन-देन शुरू करें और उम्र = 25 होने वाली तालिका से रिकॉर्ड हटाएं और अंत में हम सभी परिवर्तनों को करने के लिए COMMIT कमांड का उपयोग करें।
sqlite> BEGIN;
sqlite> DELETE FROM COMPANY WHERE AGE = 25;
sqlite> COMMIT;
यदि आप अब जाँच करते हैं कि कंपनी तालिका में अभी भी निम्नलिखित रिकॉर्ड हैं -
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
3 Teddy 23 Norway 20000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0