Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

संग्रह विधि:Oracle डेटाबेस में DELETE प्रक्रिया

Oracle डेटाबेस में प्रक्रिया हटाएं

जैसा कि संग्रह विधियों के परिचय में चर्चा की गई है, हमारे पास सात संग्रह कार्य और 3 संग्रह प्रक्रियाएं हैं। इसलिए कुल मिलाकर हमारे पास 10 संग्रह विधियां हैं जिनमें से हम अब तक 7 संग्रह कार्यों पर चर्चा कर चुके हैं। इस प्रकार आज इस ट्यूटोरियल में हम पहली PL/SQL संग्रह प्रक्रिया पर चर्चा करेंगे जो Oracle डेटाबेस में DELETE प्रक्रिया है।

PL/SQL संग्रह विधि क्या है हटाएं?

संग्रह विधि DELETE एक अतिभारित प्रक्रिया है जो संग्रह से तत्वों को हटा देती है।

एक अतिभारित प्रक्रिया से आप क्या समझते हैं?

आपने सही सुना। PL/SQL संग्रह विधि DELETE एक अतिभारित प्रक्रिया है। जिसका अर्थ है कि आप एक ही प्रक्रिया को तीन अलग-अलग तरीकों से उपयोग कर सकते हैं . ये तीन अलग-अलग तरीके हैं -

  • हटाएं :बिना किसी पैरामीटर के सरल प्रक्रिया कॉल। इस प्रकार यदि PL/SQL संग्रह प्रक्रिया DELETE का उपयोग बिना किसी पैरामीटर के किया जाता है तो यह संग्रह से सभी तत्वों को हटा देगा
  • हटाएं (इंडेक्स-नंबर ) :एकल पैरामीटर के साथ प्रक्रिया कॉल। यह एकल पैरामीटर संग्रह की मान्य अनुक्रमणिका संख्या है। संग्रह प्रक्रिया DELETE को मान्य अनुक्रमणिका संख्या पास करके कॉल किया जाएगा विशिष्ट अनुक्रमणिका के तत्व को हटा देगा
  • हटाएं (प्रारंभ-सूचकांक, समाप्ति-सूचकांक ) : दो मापदंडों के साथ प्रक्रिया कॉल। DELETE प्रक्रिया को कॉल करने के इस तरीके को रेंज डिलीट . कहा जाता है . इस तरह आपको दो इंडेक्स निर्दिष्ट करने होंगे। और प्रक्रिया प्रारंभिक-सूचकांक और समाप्ति-सूचकांक के बीच आने वाले तत्वों की श्रेणी को हटा देती है

यदि संग्रह एक स्ट्रिंग-अनुक्रमित साहचर्य सरणी है, तो प्रारंभिक-सूचकांक और समाप्ति-सूचकांक स्ट्रिंग हैं; अन्यथा प्रारंभ और समाप्ति अनुक्रमणिका पूर्णांक हैं।

क्या हम सभी संग्रहों के साथ Oracle डेटाबेस में DELETE प्रक्रिया का उपयोग कर सकते हैं?

हाँ, संग्रह विधि DELETE का उपयोग तीनों प्रकार के संग्रह में किया जा सकता है। ये हैं - नेस्टेड टेबल, VARRAYs और साहचर्य सरणियाँ।

रुको! लेकिन अगर हम VARRAYs के साथ DELETE प्रक्रिया का उपयोग करते हैं तो क्या यह विरल संग्रह नहीं करेगा?

चूंकि VARRAY एक विरल संग्रह नहीं है इसलिए हम इसमें से अलग-अलग पंक्तियों को नहीं हटा सकते हैं। इसके अलावा, एकमात्र प्रक्रिया कॉल जिसे हम VARRAY के साथ निष्पादित कर सकते हैं वह पहला है। संग्रह विधि कौन सी है DELETE बिना किसी तर्क के जो संग्रह से सभी तत्वों को हटा देती है। एक VARRAY से एक व्यक्तिगत पंक्ति को हटाने का एकमात्र तरीका TRIM को दूसरी प्रक्रिया कॉल का उपयोग करके इसके अंत से ट्रिम करना है।

क्या हम संग्रह विधि DELETE से किसी अपवाद की अपेक्षा कर सकते हैं?

हां, PL/SQL संग्रह विधि DELETE से जुड़ा एक अपवाद है। यदि प्रक्रिया DELETE को एक प्रारंभिक नेस्टेड टेबल और VARRAY पर लागू किया जाता है तो यह "Collection_is_Null" अपवाद उठाता है।

PL/SQL संग्रह विधि के उदाहरण DELETE.

आइए उपरोक्त प्रत्येक प्रक्रिया DELETE कॉल के कुछ उदाहरण देखें।

उदाहरण 1:बिना तर्क के सरल प्रक्रिया कॉल।

DECLARE
    TYPE my_nested_table IS
        TABLE OF NUMBER;
    var_nt my_nested_table := my_nested_table(2,4,6,8,10,12,14,16,18,20);
BEGIN

    --Range Delete
    var_nt.DELETE;
    FOR i IN 1..var_nt.LAST LOOP
        IF var_nt.EXISTS(i) THEN
            DBMS_OUTPUT.PUT_LINE('Value at Index ['||i||'] is '|| var_nt(i));
        END IF;
    END LOOP;
END;
/

संग्रह प्रक्रिया को कॉल करना DELETE बिना किसी तर्क के संग्रह के सभी तत्वों को हटा देगा जिस पर इसे लागू किया गया है। इसी तरह, उपरोक्त उदाहरण में हमारे पास "my_nested_table" नाम के साथ एक नेस्टेड टेबल है, जिस पर हमने DELETE प्रक्रिया लागू की है। इस प्रकार, सफल निष्पादन पर, प्रक्रिया कॉल सभी 10 संख्यात्मक तत्वों को हटा देगा जो इसमें संग्रहीत हैं।

सुझाए गए पठन:PL/SQL ब्लॉक के लिए स्थानीय नेस्टेड तालिका कैसे बनाएं।

उदाहरण 2:एकल पैरामीटर के साथ प्रक्रिया कॉल

DECLARE
    TYPE my_nested_table IS
        TABLE OF NUMBER;
    var_nt my_nested_table := my_nested_table(2,4,6,8,10,12,14,16,18,20);
BEGIN
    DBMS_OUTPUT.PUT_LINE('After Deleted');
    --Delete Specific Index
    var_nt.DELETE(5);
    IF var_nt.EXISTS(5) THEN
            DBMS_OUTPUT.PUT_LINE('Value at Index [5] is '|| var_nt(5));
    ELSE
        DBMS_OUTPUT.PUT_LINE('Data is Deleted');
    END IF;
END;
/

यह एकल पैरामीटर संग्रह की मान्य अनुक्रमणिका संख्या है। इसके अलावा, संग्रह प्रक्रिया DELETE को एक वैध इंडेक्स नंबर पास करके बुलाया जाता है, जो विशिष्ट इंडेक्स के तत्व को हटा देगा। इसलिए, उपरोक्त उदाहरण में हमने PL/SQL संग्रह विधि DELETE के तर्क के रूप में 5 निर्दिष्ट किया है। इस प्रकार, सफल निष्पादन पर प्रक्रिया कॉल उस तत्व को संग्रह से हटा देगा जो सूचकांक 5 पर संग्रहीत है।

उदाहरण 3:दो पैरामीटर के साथ प्रक्रिया कॉल।

DECLARE
    TYPE my_nested_table IS
        TABLE OF NUMBER;
    var_nt my_nested_table := my_nested_table(2,4,6,8,10,12,14,16,18,20);
BEGIN

    --Delete Range
    var_nt.DELETE(2,6);
    FOR i IN 1..var_nt.LAST LOOP
        IF var_nt.EXISTS(i) THEN
            DBMS_OUTPUT.PUT_LINE('Value at Index ['||i||'] is '|| var_nt(i));
        END IF;
    END LOOP;
END;
/

DELETE प्रक्रिया को कॉल करने के इस तरीके को रेंज डिलीट कहा जाता है। यहां आपको दो इंडेक्स निर्दिष्ट करने होंगे और प्रक्रिया उन तत्वों की श्रेणी को हटा देती है जो प्रारंभिक-सूचकांक और समाप्ति-सूचकांक के बीच आते हैं। उपरोक्त उदाहरण में हमने शुरुआती इंडेक्स को 2 के रूप में और एंडिंग इंडेक्स को 6 के रूप में सेट किया है। इसका मतलब है कि प्रक्रिया कॉल DELETE इस श्रेणी में आने वाले सभी तत्वों को हटा देगी।

आगे बढ़ें और उपरोक्त कोड को अपने SQL डेवलपर में कॉपी करें और आउटपुट क्या हैं यह देखने के लिए उन्हें स्वयं निष्पादित करें।

उपरोक्त सभी उदाहरणों की लाइव व्याख्या के लिए आप इसी विषय पर वीडियो ट्यूटोरियल भी देख सकते हैं।

यह Oracle डेटाबेस में PL/SQL संग्रह विधि DELETE पर ट्यूटोरियल है। आशा है आपको पढ़कर अच्छा लगा होगा और कुछ नया सीखा होगा। इस ब्लॉग को अपने सोशल मीडिया पर शेयर करना न भूलें। पीएल/एसक्यूएल की अधिक दिलचस्प अवधारणाओं के लिए मेरे फेसबुक पेज पर भी मुझसे जुड़ें।

धन्यवाद और आपका दिन शुभ हो!


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. IN खंड के लिए कार्य या प्रक्रिया

  2. पीएल/एसक्यूएल, स्ट्रिंग में सिंगल कोट से कैसे बचें?

  3. oracle - कई दिनांक स्वरूपों को एकल स्वरूपित दिनांक में बदलें

  4. Oracle को एक चुनिंदा खंड द्वारा परिभाषित डेटा खंड के लिए चेकसम मान मिलता है

  5. ऑरैकल में भौतिक दृश्य को रीफ्रेश कैसे करें