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

FETCH INTO Statement के साथ PL/SQL बल्क कलेक्ट क्लॉज का उपयोग कैसे करें

FETCH INTO स्टेटमेंट के साथ बल्क कलेक्ट क्लॉज

पिछले ट्यूटोरियल में हमने PL/SQL बल्क कलेक्ट के साथ SELECT-INTO स्टेटमेंट का उपयोग करके कई संदर्भ स्विच को एक में संपीड़ित करने में कामयाबी हासिल की। SELECT-INTO कथन एक SQL मानक क्वेरी है जिसका अर्थ है कि डेवलपर का कथन के निष्पादन पर अधिक नियंत्रण नहीं है।

यदि हम क्वेरी प्रदर्शन के बारे में बात करते हैं, तो हम SELECT-INTO स्टेटमेंट के साथ एक हद तक आगे नहीं बढ़ सकते हैं। आइए देखें कि हम SELECT-INTO स्टेटमेंट की इन सभी कमियों को कैसे दूर कर सकते हैं।

इस ब्लॉग में आप स्पष्ट कर्सर के FETCH-INTO स्टेटमेंट के साथ बल्क कलेक्ट क्लॉज का उपयोग करना सीखेंगे। चूंकि FETCH स्टेटमेंट कर्सर जीवन चक्र का हिस्सा हैं, इसलिए इस ट्यूटोरियल की बेहतर समझ के लिए स्पष्ट कर्सर का कार्यसाधक ज्ञान आवश्यक है। इसके लिए आप Oracle डेटाबेस में एक स्पष्ट कर्सर बनाने के तरीके पर ट्यूटोरियल देख सकते हैं।

हमें FETCH INTO स्टेटमेंट के साथ बल्क कलेक्ट क्लॉज का उपयोग क्यों करना चाहिए?

जैसा कि पिछले ब्लॉग में बताया गया है कि जब भी हम सेलेक्ट-इनटो स्टेटमेंट के साथ बल्क-कलेक्ट का इस्तेमाल करते हैं तो रनटाइम इंजन टास्क को प्रोसेस करने के लिए इंप्लिटेड कर्सर का इस्तेमाल करता है। लेकिन अगर हम FETCH-INTO स्टेटमेंट के साथ बल्क कलेक्ट का उपयोग करते हैं तो रनटाइम इंजन टास्क को प्रोसेस करने के लिए स्पष्ट कर्सर का उपयोग करेगा।

एक स्पष्ट कर्सर हमेशा हमारे मानक SQL प्रश्नों पर अग्रिम नियंत्रण प्राप्त करने में हमारी सहायता करता है। उदाहरण के लिए एक स्पष्ट कर्सर के साथ हम नियंत्रित कर सकते हैं कि रिकॉर्ड कब प्राप्त करें या कितने रिकॉर्ड हम एक बार में पुनर्प्राप्त करना चाहते हैं, हालांकि चयन-इनटो स्टेटमेंट के मामले में यह संभव नहीं है।

फ़ेच-इनटू स्टेटमेंट के साथ बल्क कलेक्ट का सिंटैक्स क्या है?

SELECT-INTO स्टेटमेंट के समान, बल्क कलेक्ट क्लॉज FETCH-INTO स्टेटमेंट की विशेषता के रूप में काम करता है। यहाँ वाक्य रचना है

FETCH <cursor_name> BULK COLLECT INTO <plsql_collection>;

FETCH स्टेटमेंट स्पष्ट कर्सर का हिस्सा हैं। यदि आप उनके पैरेंट कर्सर को घोषित किए बिना उन्हें निष्पादित करने का प्रयास करते हैं तो आपको एक त्रुटि मिलेगी। यह भी हमेशा याद रखें कि थोक संग्रह के लिए PL/SQL संग्रह ही एकमात्र समर्थित संरचना है।

उदाहरण:Oracle डाटाबेस में FETCH-INTO स्टेटमेंट के साथ PL/SQL बल्क कलेक्ट का उपयोग कैसे करें।

SET SERVEROUTPUT ON;
DECLARE
--Create an explicit cursor
    CURSOR exp_cur IS
    SELECT first_name FROM employees;

    --Declare collection for holding the data 
    TYPE nt_fName   IS TABLE OF VARCHAR2 (20);
    fname   nt_fName;
BEGIN
    OPEN exp_cur;
    LOOP
        FETCH exp_cur BULK COLLECT INTO fname;
        EXIT WHEN fname.count=0;
        --Print data
        FOR idx IN fname.FIRST.. fname.LAST
        LOOP
            DBMS_OUTPUT.PUT_LINE (idx||' '||fname(idx) );
        END LOOP; 
    END LOOP;
    CLOSE exp_cur;
END;
/

मैंने अपने YouTube चैनल पर वीडियो ट्यूटोरियल में इस पूरे कोड की हर एक लाइन के बारे में विस्तार से बताया है। आप इस ट्यूटोरियल को देख सकते हैं।

चूंकि इस कोड में हमने फ़ेच इन स्टेटमेंट के साथ बल्क कलेक्ट क्लॉज़ का उपयोग किया है, इसका मतलब है कि संदर्भ स्विचिंग कोई समस्या नहीं होगी। जैसा कि हम जानते हैं कि बल्क कलेक्ट क्लॉज कई स्विच को एक में संपीड़ित करता है ताकि आगे कोई प्रदर्शन बोतल गर्दन न हो।

लेकिन क्या इसका मतलब यह है कि यह कोड अच्छी तरह से अनुकूलित है और इसे और अधिक अनुकूलन की आवश्यकता नहीं है? या उस मामले के लिए भविष्य में क्वेरी प्रदर्शन हमारे लिए कभी कोई समस्या नहीं होगी?

इन सभी सवालों के जवाब पाने के लिए और साथ ही यह जानने के लिए बने रहें कि हम इस PL/SQL प्रोग्राम को और कैसे ऑप्टिमाइज़ कर सकते हैं।

आशा है आपको यह ब्लॉग अच्छा लगा होगा। यदि आपको कोई संदेह या प्रश्न है या आपको लगता है कि मैं इस ब्लॉग में कुछ उल्लेख करना भूल गया हूं तो मुझे मेरे फेसबुक पेज या ट्विटर पर लिखें। धन्यवाद और आपका दिन मंगलमय हो!


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मर्ज जॉइन के साथ गलत परिणाम

  2. एकाधिक व्यवहार के साथ एक प्रश्न कैसे लिखें

  3. आपको डेटा मॉडलिंग की आवश्यकता क्यों है?

  4. शीर्ष 18 मुक्त और व्यापक रूप से उपयोग किए जाने वाले, ओपन सोर्स नोएसक्यूएल डेटाबेस

  5. Network_link का उपयोग करके डेटा माइग्रेट करना