OrientDB - लेनदेन

RDBMS की तरह, OrientDB लेनदेन ACID संपत्तियों का समर्थन करता है। एtransactionडेटाबेस प्रबंधन प्रणाली के भीतर किए गए कार्य की एक इकाई शामिल है। डेटाबेस वातावरण में लेनदेन बनाए रखने के दो मुख्य कारण हैं।

  • विफलताओं से समवर्ती वसूली की अनुमति देना और सिस्टम विफल होने की स्थिति में भी डेटाबेस को सुसंगत रखना।

  • एक डेटाबेस तक पहुँचने वाले कार्यक्रमों के बीच अलगाव प्रदान करने के लिए।

डिफ़ॉल्ट रूप से, डेटाबेस ट्रांजेक्शन को ACID गुणों जैसे कि Atomic, Consistent, Isolated और Durable गुणों का पालन करना चाहिए। लेकिन ओरिएंटडीबी एक एसीआईडी ​​अनुपालन डेटाबेस है, जिसका अर्थ है कि यह अवधारणा एसीआईडी ​​का विरोधाभासी या नकारात्मक नहीं है, लेकिन यह नोएसक्यूएल डेटाबेस को संभालने के दौरान अपनी धारणा को बदलता है। एक नजर डालिए कि ACID प्रॉपर्टीज NoSQL डेटाबेस के साथ कैसे काम करती है।

Atomic - जब आप डेटाबेस को बदलने के लिए कुछ करते हैं तो परिवर्तन को काम करना चाहिए या समग्र रूप से विफल होना चाहिए।

Consistent - डेटाबेस सुसंगत रहना चाहिए।

Isolated - यदि एक ही समय में अन्य लेनदेन निष्पादित हो रहे हैं, तो उपयोगकर्ता रिकॉर्ड को समवर्ती निष्पादन में नहीं देख पाएगा।

Durable - अगर सिस्टम क्रैश (हार्डवेयर या सॉफ्टवेयर) होता है, तो डेटाबेस को बैकअप लेने में सक्षम होना चाहिए।

डेटाबेस ट्रांजैक्शन कमिट और रोलबैक कमांड्स का उपयोग करके प्राप्त किया जा सकता है।

कमिट

कमिट का अर्थ है, डेटाबेस के सभी परिवर्तनों को सहेजकर लेनदेन को बंद करना। रोलबैक का अर्थ उस डेटाबेस स्थिति को पुनर्प्राप्त करना है जहां आपने लेन-देन खोला था।

निम्न कथन COMMIT डेटाबेस कमांड का मूल सिंटैक्स है।

COMMIT

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

इस उदाहरण में, हम 'डेमो' नाम के उसी डेटाबेस का उपयोग करेंगे जो हमने इस ट्यूटोरियल के पहले अध्याय में बनाया था। हम प्रतिबद्ध लेनदेन के संचालन को देखेंगे और लेनदेन का उपयोग करके एक रिकॉर्ड स्टोर करेंगे।

आपको पहले निम्नलिखित BEGIN कमांड का उपयोग करके लेनदेन शुरू करना होगा।

orientdb {db = demo}> BEGIN

निम्नलिखित आदेश का उपयोग करके आईडी = 12 और नाम = satish.P के साथ एक कर्मचारी तालिका में एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

लेन-देन करने के लिए आप निम्न आदेश का उपयोग कर सकते हैं।

orientdb> commit

यदि यह लेन-देन सफलतापूर्वक किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

Transaction 2 has been committed in 4ms

रोलबैक

रोलबैक का अर्थ उस डेटाबेस स्थिति को पुनर्प्राप्त करना है जहां आपने लेन-देन खोला है।

निम्न कथन ROLLBACK डेटाबेस कमांड का मूल सिंटैक्स है।

ROLLBACK

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

इस उदाहरण में, हम 'डेमो' नाम के उसी डेटाबेस का उपयोग करेंगे जो हमने ट्यूटोरियल के पुराने अध्याय में बनाया था। हम रोलबैक लेन-देन के संचालन को देखेंगे और लेनदेन का उपयोग करके एक रिकॉर्ड स्टोर करेंगे।

आपको पहले निम्नलिखित BEGIN कमांड का उपयोग करके लेनदेन शुरू करना होगा।

orientdb {db = demo}> BEGIN

निम्नलिखित आदेश का उपयोग करके आईडी = 12 और नाम = satish.P के साथ एक कर्मचारी तालिका में एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

टेबल कर्मचारी के रिकॉर्ड को पुनः प्राप्त करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

यदि इस कमांड को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

---+-------+-------------------- 
 # | ID   | name 
---+-------+-------------------- 
 0 | 12   | satish.P 
---+-------+-------------------- 
1 item(s) found. Query executed in 0.076 sec(s).

आप इस लेनदेन को रोलबैक करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

orientdb> ROLLBACK

कर्मचारी तालिका से उसी रिकॉर्ड को पुनः प्राप्त करने के लिए फिर से चयन क्वेरी की जाँच करें।

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

यदि रोलबैक को सफलतापूर्वक निष्पादित किया जाता है, तो आपको आउटपुट में 0 रिकॉर्ड मिलेंगे।

0 item(s) found. Query executed in 0.037 sec(s).