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