MariaDB - लेन-देन
लेन-देन अनुक्रमिक समूह संचालन हैं। वे एक एकल इकाई के रूप में कार्य करते हैं, और तब तक समाप्त नहीं होते हैं जब तक कि समूह के भीतर सभी ऑपरेशन सफलतापूर्वक निष्पादित नहीं हो जाते हैं। समूह में एक एकल विफलता पूरे लेनदेन को विफल करने का कारण बनती है, और इसके कारण डेटाबेस पर कोई प्रभाव नहीं पड़ता है।
लेनदेन ACID (एटमॉसिटी, कंसिस्टेंसी, अलगाव और स्थायित्व) के अनुरूप होते हैं -
Atomicity - यह विफलताओं पर गर्भपात और वापस परिवर्तनों को रोल करके सभी कार्यों की सफलता सुनिश्चित करता है।
Consistency - यह सुनिश्चित करता है कि डेटाबेस एक सफल लेनदेन पर परिवर्तन लागू करता है।
Isolation - यह लेनदेन के स्वतंत्र लेनदेन संचालन को सक्षम करता है।
Durability - यह सिस्टम की विफलता की स्थिति में एक सफल लेनदेन की दृढ़ता सुनिश्चित करता है।
एक लेन-देन विवरण के मुखिया पर COMMIT और ROLLBACK कथनों के बाद शुरू किया गया START TRANSACTION कथन है -
स्टार्ट ट्रांजेक्शन शुरू होता है।
COMMIT डेटा में परिवर्तन बचाता है।
रोलबैक लेनदेन को समाप्त करता है, किसी भी परिवर्तन को नष्ट करता है।
एक सफल लेनदेन पर, COMMIT कार्य करता है। विफलता पर, रोलबैक कार्य करता है।
Note- कुछ कथनों में निहितार्थ होता है, और लेन-देन के दौरान उपयोग करने में त्रुटि भी होती है। ऐसे बयानों के उदाहरणों में शामिल हैं, लेकिन क्रिएट, अलर्ट और डीआरओपी तक सीमित नहीं हैं।
मारियाडीबी लेनदेन में SAVEPOINT और LOCK TABLES जैसे विकल्प भी शामिल हैं। SAVEPOINT ROLLBACK के साथ उपयोग करने के लिए एक पुनर्स्थापना बिंदु सेट करता है। कुछ समय के दौरान संशोधनों को रोकने के लिए सत्र के दौरान तालिकाओं को नियंत्रित करने की अनुमति देता है।
AUTOCOMMIT चर लेनदेन पर नियंत्रण प्रदान करता है। 1 संचालन की एक सेटिंग को सफल लेनदेन माना जाने वाला सभी कार्यों को बाध्य करता है, और 0 की एक सेटिंग केवल स्पष्ट स्पष्ट विवरण पर होने वाले परिवर्तनों की दृढ़ता का कारण बनती है।
एक लेनदेन की संरचना
लेन-देन विवरण की सामान्य संरचना में स्टार्ट ट्रांसक्शन के साथ शुरुआत होती है। अगला कदम एक या एक से अधिक कमांड / ऑपरेशंस डाल रहा है, त्रुटियों की जांच करने वाले स्टेटमेंट्स डाल रहा है, खोजे गए किसी भी एरर को मैनेज करने के लिए ROLLBACK स्टेटमेंट्स डाल रहा है और आखिरकार सफल ऑपरेशंस पर बदलाव लागू करने के लिए COMMIT स्टेटमेंट डाल रहा है।
नीचे दिए गए उदाहरण की समीक्षा करें -
START TRANSACTION;
SELECT name FROM products WHERE manufacturer = 'XYZ Corp';
UPDATE spring_products SET item = name;
COMMIT;