सबसे पहले, मुझे लगता है कि हम सिंटैक्स त्रुटियों को अनदेखा कर सकते हैं (उदाहरण के लिए, कोई END LOOP
नहीं है। , dbms_output.put_line
कॉल में पहला सिंगल कोट नहीं है, आदि)
परिवर्तनों को वापस लेना आवश्यक है या नहीं, यह निर्भर करता है।
सामान्य तौर पर, आपके पास लूप में अंतरिम कमिट नहीं होगा। यह आम तौर पर एक खराब वास्तुकला है क्योंकि यह I/O और बीता हुआ समय के मामले में बहुत अधिक महंगा है। यह पुनरारंभ करने योग्य कोड लिखना भी कठिन बनाता है। क्या होता है, उदाहरण के लिए, यदि आपका SELECT
कथन 10 पंक्तियों का चयन करता है, आप 5 अपडेट जारी करते हैं (और प्रतिबद्ध), और फिर 6 वां अपडेट विफल हो जाता है? अपवाद को ठीक करने के बाद छठी पंक्ति के साथ पुनरारंभ करने में सक्षम होने का एकमात्र तरीका एक अलग तालिका होगी जहां आपने अपने कोड की प्रगति को संग्रहीत (और अपडेट) किया था। यह किसी भी कोड के लिए समस्याएँ भी पैदा करता है जो इस ब्लॉक को कॉल करता है जिसे तब इस मामले को संभालना होता है कि आधा काम किया गया था (और प्रतिबद्ध था) और दूसरा आधा नहीं था।
सामान्य तौर पर, आप केवल अपने कोड के सबसे बाहरी ब्लॉक में लेनदेन नियंत्रण विवरण डालेंगे। चूंकि COMMIT
या एक ROLLBACK
एक प्रक्रिया में सत्र में किए गए किसी भी कार्य को करता है या वापस लेता है चाहे वह प्रक्रिया द्वारा किया गया हो या नहीं, आप लेनदेन नियंत्रण विवरण जोड़ने के बारे में बहुत सतर्क रहना चाहते हैं। आप आम तौर पर कॉल करने वाले को यह निर्धारित करने देना चाहते हैं कि क्या करना है या वापस रोल करना है। बेशक, यह केवल इतना आगे जाता है-- अंत में, आप सबसे बाहरी ब्लॉक में होने जा रहे हैं जिसे कभी भी किसी अन्य रूटीन से नहीं बुलाया जाएगा और आपको उचित लेनदेन नियंत्रण की आवश्यकता है- लेकिन यह बहुत सावधान रहने वाली बात है इस बारे में कि यदि आप कोड लिख रहे हैं जिसका पुन:उपयोग किया जा सकता है।
इस मामले में, चूंकि आपके पास अंतरिम प्रतिबद्धताएं हैं, आपके ROLLBACK
. का एकमात्र प्रभाव यह होगा कि यदि पहला अपडेट स्टेटमेंट विफल हो जाता है, तो इस ब्लॉक को कॉल करने से पहले आपके सत्र में जो काम किया गया था, उसे वापस ले लिया जाएगा। यदि पहला अद्यतन विवरण सफल होता है तो अंतरिम प्रतिबद्धता उन पिछले परिवर्तनों को प्रतिबद्ध करेगी। जब लोग इस बारे में बात करते हैं कि अंतरिम प्रतिबद्धता और पुन:प्रयोज्य ब्लॉकों में लेनदेन नियंत्रण समस्याग्रस्त क्यों हैं, तो यह उस तरह का दुष्प्रभाव है जिसके बारे में लोग चिंता करते हैं।