यदि आप एक प्रोग्रामर हैं, तो आप अपवाद की अवधारणा से परिचित हो सकते हैं । चूंकि त्रुटियां अपरिहार्य हैं और यहां तक कि सबसे चतुर भी कोड लिखते समय गलतियां कर सकते हैं, हमें उनसे परिचित होना चाहिए कि उन्हें कैसे संभालना है। इस लेख में, हम विशेष रूप से PL / SQL में अपवाद हैंडलिंग के बारे में सीखेंगे।
नीचे इस लेख में शामिल विषय दिए गए हैं:
एक अपवाद क्या है?
कोई भी असामान्य स्थिति या घटना जो हमारे कार्यक्रम निर्देशों के सामान्य प्रवाह को समय पर या सरल शब्दों में बाधित करती है एक अपवाद एक त्रुटि है।
PL / SQL में अपवाद हैंडलिंग का सिंटैक्स
DECLARE BEGIN EXCEPTION जब अपवाद १ से था तो १ अपवाद-हैंडलिंग-स्टेटमेंट जब भी अपवाद २ से जुड़ा हुआ था २-हैंडलिंग-स्टेटमेंट जब अपवाद ३-हैंडलिंग-स्टेटमेंट्स ........ तो दूसरों के अपवाद ३-हैंडलिंग-स्टेटमेंट END
यहां, हम कई अपवादों को सूचीबद्ध कर सकते हैं, जिन्हें हम संभालना चाहते हैं। डिफ़ॉल्ट अपवाद को exception जब अन्य लोगों ’का उपयोग करके नियंत्रित किया जाएगा
पीएल / एसक्यूएल में अपवाद हैंडलिंग का उदाहरण
नीचे दिया गया कार्यक्रम उस छात्र का नाम और पता प्रदर्शित करता है, जिसकी आईडी दी गई है। चूंकि हमारे डेटाबेस में आईडी मान 8 के साथ कोई छात्र नहीं है, इसलिए प्रोग्राम रन-टाइम अपवाद NO_DATA_FOUND उठाता है, जो EXCEPTION ब्लॉक में कैप्चर किया गया है।
DECLARE s_id studentS.id% type: = 8 s_name studentS.Name% type s_loc studentS.loc% type BEGIN SELECT नाम, loation INTO s_name, s_loc छात्रों के लिए WHERE आईडी = s_id DBMS_OUTPUT.PUT_LINE ('नाम:' s_name) .PUT_LINE ('स्थान:' || s_loc) EXCEPTION WHEN no_data_found THEN dbms_output.put_line ('ऐसा कोई छात्र नहीं!') जब दूसरों ने dbb_output.put_line ('उफ़, त्रुटि!') END।
आउटपुट
ऐसा कोई छात्र नहीं! PL / SQL प्रक्रिया सफलतापूर्वक पूर्ण हुई।
यहां, हम कई अपवादों को सूचीबद्ध कर सकते हैं, जिन्हें हम संभालना चाहते हैं। डिफ़ॉल्ट अपवाद ‘का उपयोग करके नियंत्रित किया जाएगा जब दूसरों को '
PL / SQL में अपवाद के प्रकार
- सिस्टम परिभाषित किया गया
- उपयोगकर्ता ने टाल दिया
इस लेख में अगला अपवाद हैंडलिंग पर है पीएल / एसक्यूएल आइए इन दोनों प्रकारों के बारे में विस्तार से चर्चा करें।
सिस्टम परिभाषित किया गया
Oracle सर्वर द्वारा परिभाषित और अनुरक्षित बनाए गए, ये अपवाद मुख्य रूप से Oracle मानक पैकेज में परिभाषित किए गए हैं। जब भी प्रोग्राम के अंदर कोई अपवाद होता है, ओरेकल सर्वर मेल खाता है और ओरेकल मानक पैकेज में उपलब्ध अपवादों के उपलब्ध सेट से उपयुक्त अपवाद की पहचान करता है। असल में, इन अपवादों को पूर्वनिर्धारित किया जाता है पीएल / एसक्यूएल जो उठ जाता है जब विशेष डेटाबेस नियम का उल्लंघन किया जाता है ।
द सिस्टम-परिभाषित अपवाद आगे दो श्रेणियों में विभाजित किया गया है:
- नामित प्रणाली अपवाद
- सिस्टम अपवाद
नामित प्रणाली अपवाद
नामित PL / SQL अपवाद हैं पीएल / एसक्यूएल के मानक पैकेज में नामित , इसलिए डेवलपर को अपने कोड में PL / SQL अपवाद को परिभाषित करने की आवश्यकता नहीं है। पीएल / एसक्यूएल कई पूर्व-निर्धारित नामित अपवाद प्रदान करता है, जिन्हें किसी भी डेटाबेस नियम का उल्लंघन करने पर निष्पादित किया जाता है। निम्न तालिका कुछ महत्वपूर्ण पूर्व-परिभाषित अपवादों और ऋणों को सूचीबद्ध करती है
अपवाद | Oracle त्रुटि | SQLCODE | विवरण |
ACCESS_INTO_NULL | 06530 है | -6530 | यह तब उठाया जाता है जब एक अशक्त वस्तु को स्वचालित रूप से एक मान दिया जाता है। |
CASE_NOT_FOUND | 06592 है | -6592 | यह तब उठाया जाता है जब विकल्पों में से कोई भी WHEN के खंड में नहीं होता है मामला बयान चयनित है, और कोई ईएलएसई खंड नहीं है। |
COLLECTION_IS_NULL | 06531 है | -6531 | यह तब उठाया जाता है जब कोई प्रोग्राम किसी अनइंस्टॉलिज्ड नेस्टेड टेबल या वेरिएंट के अलावा EXISTS के अलावा अन्य कलेक्शन के तरीकों को लागू करने का प्रयास करता है, या प्रोग्राम एक अनइंस्टाल्यूटेड नेस्टेड टेबल या वेरिए के तत्वों को मान असाइन करने का प्रयास करता है। |
DUP_VAL_ON_INDEX | 00001 | -एक | यह तब उठाया जाता है जब डुप्लिकेट मानों को एक अद्वितीय सूचकांक वाले कॉलम में संग्रहीत करने का प्रयास किया जाता है। |
INVALID_CURSOR | 01001 है | -1001 | यह तब उठाया जाता है जब एक कर्सर ऑपरेशन बनाने की कोशिश की जाती है जिसे अनुमति नहीं दी जाती है, जैसे कि बिना बंद किए गए कर्सर को बंद करना। |
अमान्य संख्या | 01722 है | -1722 | यह तब उठाया जाता है जब वर्ण स्ट्रिंग का संख्या में रूपांतरण विफल हो जाता है क्योंकि स्ट्रिंग एक मान्य संख्या का प्रतिनिधित्व नहीं करती है। |
LOGIN_DENIED | 01017 | -1017 | यह तब उठाया जाता है जब कोई प्रोग्राम किसी अमान्य उपयोगकर्ता नाम या पासवर्ड के साथ डेटाबेस पर लॉग ऑन करने का प्रयास करता है। |
कोई डेटा नहीं मिला | 01403 है | +100 | इसे तब चुना जाता है जब कोई SELECT INTO स्टेटमेंट कोई पंक्तियाँ नहीं लौटाता है। |
NOT_LOGGED_ON | 01012 | -1012 | डेटाबेस से कनेक्ट किए बिना डेटाबेस कॉल जारी किए जाने पर इसे उठाया जाता है। |
PROGRAM_ERROR | 06501 है | -6501 | यह तब उठाया जाता है जब PL / SQL में आंतरिक समस्या होती है। |
ROWTYPE_MISMATCH | 06504 है | -6504 है | यह तब उठाया जाता है जब एक कर्सर असंगत डेटा प्रकार वाले चर में मूल्य प्राप्त करता है। |
SELF_IS_NULL | 30625 है | -30625 | यह तब उठाया जाता है जब एक सदस्य विधि लागू की जाती है, लेकिन ऑब्जेक्ट प्रकार का उदाहरण प्रारंभिक नहीं था। |
STORAGE_ERROR | 06500 रु | -6500 रु | यह तब उठाया जाता है जब पीएल / एसक्यूएल मेमोरी से बाहर हो गया या मेमोरी दूषित हो गई थी। |
TOO_MANY_ROWS | 01422 है | -1422 | यह तब उठाया जाता है जब एक SELECT INTO स्टेटमेंट एक से अधिक पंक्ति में लौटता है। |
VALUE_ERROR | 06502 | -6502 है | यह तब उठाया जाता है जब एक अंकगणित, रूपांतरण, छंटनी या आकार की बाधा उत्पन्न होती है। |
ZERO_DIVIDE | 01476 है | 1476 | यह तब उठाया जाता है जब किसी संख्या को शून्य से विभाजित करने का प्रयास किया जाता है। |
उदाहरण
सृजन या समीक्षा प्रक्रिया add_new_student (छात्र _id_in इन NUMBER, छात्र _name_IN IN VARCHAR2) IS BEGIN INSERT INTO छात्र (छात्र _id, छात्र _name): विद्यार्थी (_id_in, छात्र _name_in) छात्र DUP_V_V_AL_IN_Suddy ) जब दूसरों को उठाएं______प्रतिबंध__रचना (-20002, 'एक त्रुटि हुई।') END
पीएल / एसक्यूएल में अपवाद हैंडलिंग पर इस लेख में आगे बढ़ते हुए, आइए समझते हैं कि अनाम सिस्टम अपवाद क्या हैं।
सिस्टम अपवाद
सिस्टम अपवाद जिसके लिए ओरेकल का नाम नहीं है, को अनाम सिस्टम अपवाद के रूप में जाना जाता है। ये अपवाद अक्सर नहीं होते हैं और एक कोड और एक संबद्ध संदेश के साथ लिखे जाते हैं।
अनाम सिस्टम अपवादों को संभालने के लिए मूल रूप से दो तरीके हैं:
1. जब दूसरों के अपवाद हैंडलर का उपयोग करना
2. अपवाद कोड को एक नाम से जोड़ना और इसे नामित अपवाद के रूप में उपयोग करना।
अनाम सिस्टम अपवादों के लिए कुछ कदम निम्नलिखित हैं:
- उन्हें स्पष्ट रूप से उठाएं।
- यदि उन्हें then जब अन्य ’में संभाला नहीं जाता है, तो उन्हें स्पष्ट रूप से संभाला जाना चाहिए।
- स्पष्ट रूप से अपवाद को संभालने के लिए, उन्हें प्रैग एक्सेप्टन_INIT का उपयोग करके घोषित किया जा सकता है और अपवाद खंड में उपयोगकर्ता-परिभाषित अपवाद नाम को संदर्भित करके नियंत्रित किया जा सकता है।
प्रागमा EXCEPTION_INIT का उपयोग करते हुए अनाम अपवादों से निपटने का एक उदाहरण लेख में बाद में प्रदान किया गया है। पीएल / एसक्यूएल में अपवाद हैंडलिंग पर इस लेख में आगे बढ़ते हुए, आइए हम उपयोगकर्ता द्वारा परिभाषित एक्सपट्र्स को समझें।
उपयोगकर्ता परिभाषित
अन्य सभी प्रोग्रामिंग भाषाओं की तरह, ओरेकल भी आपको अपने स्वयं के अपवादों को लागू करने की घोषणा करने की अनुमति देता है। सिस्टम परिभाषित अपवादों के विपरीत, ये अपवाद PL / SQL ब्लॉक में स्पष्ट रूप से उठाए गए हैं।
Oracle डेटाबेस में उपयोगकर्ता-परिभाषित अपवाद घोषित करने के लिए कदम
हम निम्नलिखित 3 तरीकों से Oracle डेटाबेस में उपयोगकर्ता-परिभाषित अपवादों को परिभाषित कर सकते हैं:
- अपवाद प्रकार के चर का उपयोग करना
यहां, हम EXCEPTION के एक चर को घोषित करके उपयोगकर्ता-परिभाषित अपवाद की घोषणा कर सकते हैं डाटा प्रकार हमारे कोड में और RAISE स्टेटमेंट का उपयोग करके हमारे कार्यक्रम में इसे स्पष्ट रूप से बढ़ाएं।
- PRAGMA EXCEPTION_INIT फ़ंक्शन का उपयोग करना
हम एक पूर्वनिर्धारित त्रुटि संख्या को EXCEPTION डेटाटाइप के चर के साथ परिभाषित कर सकते हैं
- RAISE_APPLICATION_ERROR विधि का उपयोग करना
इस पद्धति का उपयोग करके, हम अपने स्वयं के अनुकूलित त्रुटि संख्या और संदेश के साथ एक उपयोगकर्ता-परिभाषित अपवाद घोषित कर सकते हैं।
अब तक आपको पीएल / एसक्यूएल में उपयोगकर्ता-परिभाषित अपवादों को बढ़ाने के तरीकों पर एक मोटा विचार मिल गया होगा। हम पीएल / एसक्यूएल में अपवाद हैंडलिंग पर इस लेख में आगे दिए गए उदाहरणों में से प्रत्येक के बारे में सीखेंगे।
इस लेख में आगे, आइए हम उपयोगकर्ता द्वारा परिभाषित अपवाद हैंडलिंग के प्रदर्शनों के साथ आगे बढ़ें।
उपयोगकर्ता द्वारा परिभाषित अपवादों का प्रदर्शन
पीएल / एसक्यूएल में एक्सेप्शन हैंडलिंग पर इस लेख में आगे बढ़ते हुए, आइए हम समझते हैं कि एक्सेप्टिशन प्रकार के चर का उपयोग कैसे करें।
अपवाद प्रकार के चर का उपयोग करना
उपयोगकर्ता-परिभाषित अपवाद घोषित करने की प्रक्रिया को तीन भागों में विभाजित किया गया है और ये 3 भाग हैं:
- एक चर अपवाद डेटाटाइप की घोषणा करें
- अपवाद उठाएं
- अपवाद को संभालें
उपरोक्त चरणों को प्रदर्शित करने के लिए एक कोड लिखें।
DECLARE var_dividend NUMBER: = 10 var_divisor NUMBER: = 0 var_result NUMBER पूर्व-डिवजेरो EXCEPTION
उपरोक्त घोषणा ब्लॉक में, हमारे पास चार चर हैं, जिनमें से पहले तीन सामान्य संख्या डेटाटाइप चर हैं और चौथा जो ex_DivZero है वह विशेष अपवाद डेटाटाइप चर है। चौथा हमारे उपयोगकर्ता द्वारा परिभाषित अपवाद है।
DECLARE var_dividend NUMBER: = 10 var_divisor NUMBER: = 0 var_result NUMBER पूर्व-डिवजेरो EXCEPTION
इस अनाम ब्लॉक का उपरोक्त निष्पादन भाग, तब ही क्रिया में आएगा जब भाजक 0. है। यदि विभाजक शून्य है जैसा कि हमारे मामले में है, तो त्रुटि उठाई जाएगी और कार्यक्रम का नियंत्रण अगले सभी चरणों को छोड़ देगा। अपवाद हैंडलर मिलान के लिए दिखेगा। इस मामले में जहां यह किसी अन्य को पाता है, यह तदनुसार कार्रवाई करेगा, अन्यथा यह या तो कार्यक्रम को समाप्त कर देगा या हमें एक अनहेल्दी सिस्टम परिभाषित त्रुटि के साथ संकेत देगा।
जब EX_DivZero से DBMS_OUTPUT.PUT_LINE (The त्रुटि, विभाजक शून्य नहीं हो सकता)
यह अपवाद हैंडलर है। जैसे ही उपयोगकर्ता 0 के रूप में विभाजक दर्ज करता है, उपरोक्त संदेश स्ट्रिंग को संकेत दिया जाएगा।
अंतिम कोड:
DECLARE var_dividend NUMBER: = 10 var_divisor NUMBER: = 0 var_result NUMBER ex-DivZero EXCEPTION BEGIN अगर var_divisor = 0 THEN RAISE ex-DivZero NUMBER वरुण_result: = var_dividend / var_divisor DBMS_OUTPUT_LINE_IN_INVITEN_IN से अलग है। = 0 फिर से एक्स-डिवेज़रो END करें यदि Var_result: = var_dividend / var_divisor DBMS_OUTPUT.PUT_LINE ('परिणाम =' || var_result) END
पीएल / एसक्यूएल में अपवाद हैंडलिंग पर इस लेख में आगे बढ़ते हुए, हमें समझते हैं कि कैसे PRAGMA_EXCEPTION_INIT विधि का उपयोग करें।
PRAGMA EXCEPTION_INIT फ़ंक्शन का उपयोग करना
में PRAGMA EXCEPTION_INIT फ़ंक्शन, एक अपवाद नाम Oracle त्रुटि संख्या के साथ जुड़ा हुआ है। इस नाम का उपयोग त्रुटि के लिए अपवाद हैंडलर को डिजाइन करने में किया जा सकता है।कई उपयोगकर्ता परिभाषित त्रुटियों वाली विशाल परियोजनाओं के लिए, PRAGMA EXCEPTION_INIT सबसे उपयोगी और उपयुक्त विधि है।
वाक्य - विन्यास:
PRAGMA EXCEPTION_INIT (अपवाद_name; -Oracle_error_number)
उदाहरण
DECLARE deadlock_detected EXCEPTION PRAGMA EXCEPTION_INIT (deadlock_detected, -60) BEGIN NULL - कुछ ऑपरेशन जो ORA-00060 त्रुटि का कारण बनता है EXCEPTION WHAT deadlock_detected THEN NULL - त्रुटि END को हैंडल करें
PRAGMA EXCEPTION_INIT कंपाइलर को अपवाद नाम को Oracle त्रुटि संख्या के साथ संबद्ध करने के लिए कहता है जैसा कि पहले बताया गया है। यह आपको नाम से किसी भी आंतरिक अपवाद को संदर्भित करता है और इसके लिए एक विशिष्ट हैंडलर लिखता है। जब आप एक त्रुटि स्टैक, या त्रुटि संदेशों का क्रम देखते हैं, तो शीर्ष पर एक वह है जिसे फँसाया और संभाला जा सकता है।
जावा घोषित वस्तुओं की सरणी
पीएल / एसक्यूएल में अपवाद हैंडलिंग पर इस लेख में आगे बढ़ते हुए, आइए समझते हैं कि RAISE_APPLICATION_ERPLOR विधि का उपयोग कैसे करें।
RAISE_APPLICATION_ERROR विधि का उपयोग करना
यह एक प्रक्रिया है जो ओरेकल सॉफ्टवेयर के साथ इनबिल्ट होती है। इस प्रक्रिया का उपयोग करके हम एक त्रुटि संख्या को एक कस्टम त्रुटि संदेश के साथ जोड़ सकते हैं। त्रुटि संख्या और कस्टम त्रुटि संदेश दोनों को मिलाते हुए, एक त्रुटि स्ट्रिंग बनाई जा सकती है जो उन डिफ़ॉल्ट त्रुटि स्ट्रिंग के समान दिखती है जो त्रुटि सामने आने पर oracle द्वारा प्रदर्शित की जाती हैं। RAISE_APPLICATION_ERROR प्रक्रिया DBMS_STANDARD पैकेज के अंदर पाई जाती है
वाक्य - विन्यास
up_application_error (error_number, संदेश [, TRUE])
उदाहरण
/ * एक ट्रिगर trg_emp_detail_chk बनाया गया है। * / बनाएँ या ट्रैक TRIGGER trg_emp_detail_chk / * ट्रिगर समय को EMPLOYEES टेबल पर BEDORE UPDATE के रूप में घोषित किया गया है। * / कर्मचारियों के सामने आने से पहले अनुमति के लिए अनुमति न दें। सिस्टम समय का दिन शनिवार या रविवार है या नहीं। * / IF ट्रिम (TO_CHAR (sysdate, 'दिन')) IN ('शनिवार', 'रविवार') THEN raise_application_error (-20000, 'आप करने के लिए अधिकृत नहीं हैं सप्ताहांत में कोई भी संशोधन !! ') / * प्रक्रिया को बढ़ाने के लिए-पैरामीटर को -20000 के रूप में कहा जाता है और दूसरा पैरामीटर डिफ़ॉल्ट पाठ के साथ दूसरा पैरामीटर यह कहते हुए कि उपयोगकर्ता सप्ताहांत में किसी भी संशोधन को करने के लिए अधिकृत नहीं है। * / END IF END
इसके साथ हम 'पीएल / एसक्यूएल में अपवाद हैंडलिंग' पर इस लेख के अंत में आते हैं। मुझे उम्मीद है कि इस विषय को अच्छी तरह से समझा गया है और आपने मदद की है। अपने स्वयं के कोड लिखने की कोशिश करें और इस लेख में बताए गए तरीकों को शामिल करें।
यदि आप इस तकनीक पर पेशेवरों से प्रशिक्षित होना चाहते हैं, तो आप edureka से संरचित प्रशिक्षण का विकल्प चुन सकते हैं! इसकी जांच करो 250,000 से अधिक संतुष्ट शिक्षार्थियों के एक नेटवर्क के साथ एक विश्वसनीय ऑनलाइन शिक्षण कंपनी, एडुरेका द्वारा, दुनिया भर में फैली हुई है। यह कोर्स आपको डेटा का प्रबंधन करने और MySQL डेटाबेस को प्रबंधित करने के लिए मुख्य अवधारणाओं और उन्नत टूल और तकनीकों पर प्रशिक्षित करता है। इसमें MySQL वर्कबेंच, MySQL सर्वर, डेटा मॉडलिंग, MySQL कनेक्टर, डेटाबेस डिज़ाइन, MySQL कमांड लाइन, MySQL फ़ंक्शंस आदि जैसी अवधारणाओं को सीखना शामिल है। प्रशिक्षण के अंत में आप अपने स्वयं के MySQL डेटाबेस को बनाने और प्रबंधित करने में सक्षम होंगे। डेटा।
क्या आप हमसे कोई प्रश्न पूछना चाहते हैं? कृपया इसे 'पीएल / एसक्यूएल में अपवाद हैंडलिंग' लेख के टिप्पणी अनुभाग में उल्लेख करें और हम जल्द से जल्द आपके पास वापस आ जाएंगे।