SAP ABAP - आंतरिक तालिकाएँ बनाना
आंतरिक तालिका घोषित करने के लिए DATA स्टेटमेंट का उपयोग किया जाता है। कार्यक्रम को बताया जाना चाहिए कि तालिका कहाँ से शुरू और समाप्त होती है। इसलिए BEGIN OF स्टेटमेंट का उपयोग करें और फिर टेबल का नाम घोषित करें। इसके बाद, OCCURS जोड़ का उपयोग किया जाता है, इसके बाद एक नंबर आता है। यहां OCCURS SAP को बताता है कि एक आंतरिक तालिका बनाई जा रही है, और 0 में कहा गया है कि इसमें शुरू में कोई रिकॉर्ड नहीं होगा। इसके बाद इसका विस्तार होगा क्योंकि यह डेटा से भरा है।
निम्नलिखित वाक्य रचना है -
DATA: BEGIN OF <internal_tab> Occurs 0,
चलिए खेतों को एक नई लाइन पर बनाते हैं। उदाहरण के लिए, 'नाम' बनाएं जिसे LIKE ZCUSTOMERS1-name के रूप में घोषित किया गया है। 'Dob' नामक एक और फ़ील्ड बनाएँ, ZCUSTOMERS1-dob को LIKE करें। आंतरिक तालिकाओं में फ़ील्ड नामों को अन्य क्षेत्रों के समान नाम देने के लिए प्रारंभ में उपयोगी है जो अन्य जगहों पर बनाए गए हैं। अंत में, "END OF <internal_tab>" के साथ आंतरिक तालिका के अंत की घोषणा करें। जैसा कि निम्नलिखित कोड में दिखाया गया है -
DATA: BEGIN OF itab01 Occurs 0,
name LIKE ZCUSTOMERS1-name,
dob LIKE ZCUSTOMERS1-dob,
END OF itab01.
SAP में अस्थायी तालिकाएँ बनाते समय 'itab01' का आमतौर पर इस्तेमाल किया जाता है। OCCURS क्लॉज का उपयोग तालिका के लिए फ़ील्ड घोषित करके एक आंतरिक तालिका के शरीर को परिभाषित करने के लिए किया जाता है। जब OCCURS क्लॉज का उपयोग किया जाता है, तो आप आवश्यकता होने पर अतिरिक्त डिफ़ॉल्ट मेमोरी निर्धारित करने के लिए एक संख्यात्मक स्थिर 'n' निर्दिष्ट कर सकते हैं। OCCUR 0 खंड द्वारा उपयोग की जाने वाली मेमोरी का डिफ़ॉल्ट आकार 8 KB है। आंतरिक तालिका की संरचना अब बनाई गई है, और कोड को रिकॉर्ड के साथ भरने के लिए लिखा जा सकता है।
एक हेडर लाइन का उपयोग किए बिना या बिना एक आंतरिक तालिका बनाई जा सकती है। एक हेडर लाइन के साथ एक आंतरिक तालिका बनाने के लिए, OCCURS क्लॉज से पहले BEGIN OF clause या आंतरिक तालिका की परिभाषा में OCCURS क्लॉज के बाद HEADER LINE क्लॉज का उपयोग करें। हेडर लाइन के बिना एक आंतरिक तालिका बनाने के लिए, BEGIN OF क्लॉज के बिना OCCURS क्लॉज का उपयोग करें।
आप TYID स्टेटमेंट का उपयोग करके स्थानीय डेटा प्रकार (केवल वर्तमान प्रोग्राम के संदर्भ में उपयोग किया जाने वाला डेटा प्रकार) के रूप में एक आंतरिक तालिका भी बना सकते हैं। यह कथन मौजूदा तालिका को संदर्भित करने के लिए TYPE या LIKE क्लॉज का उपयोग करता है।
स्थानीय डेटा प्रकार के रूप में एक आंतरिक तालिका बनाने का वाक्य विन्यास है -
TYPES <internal_tab> TYPE|LIKE <internal_tab_type> OF
<line_type_itab> WITH <key> INITIAL SIZE <size_number>.
यहां <आंतरिक_टैब_टाइप> एक आंतरिक तालिका के लिए तालिका प्रकार निर्दिष्ट करता है <आंतरिक_टैब> और <पंक्ति_टाइप_टैब> एक आंतरिक तालिका की एक पंक्ति के लिए प्रकार निर्दिष्ट करता है। TYPES स्टेटमेंट में, आप डेटा प्रकार के रूप में आंतरिक तालिका के लाइन प्रकार को निर्दिष्ट करने के लिए TYPE क्लॉज का उपयोग कर सकते हैं और लाइन ऑब्जेक्ट को डेटा ऑब्जेक्ट के रूप में निर्दिष्ट करने के लिए LIKE क्लॉज। एक आंतरिक तालिका के लिए एक कुंजी निर्दिष्ट करना वैकल्पिक है और यदि उपयोगकर्ता एक कुंजी निर्दिष्ट नहीं करता है, तो SAP सिस्टम एक तालिका प्रकार को एक मनमानी कुंजी के साथ परिभाषित करता है।
प्रारंभिक आकार <size_number> इसकी एक प्रारंभिक मात्रा आवंटित करके आंतरिक तालिका ऑब्जेक्ट बनाता है। पूर्ववर्ती सिंटैक्स में, INIZIAL SIZE क्लॉज़ size_number टेबल लाइनों के लिए मेमोरी स्पेस रखता है। जब भी किसी आंतरिक तालिका ऑब्जेक्ट को घोषित किया जाता है, तो तालिका का आकार तालिका के डेटा प्रकार से संबंधित नहीं होता है।
Note - आंतरिक तालिका के पहली बार पॉप्युलेट होने पर बहुत कम मेमोरी खपत होती है।
उदाहरण
Step 1- SE38 लेनदेन कोड निष्पादित करके ABAP संपादक खोलें। ABAP संपादक की प्रारंभिक स्क्रीन दिखाई देती है।
Step 2 - प्रारंभिक स्क्रीन में, प्रोग्राम के लिए एक नाम दर्ज करें, सोर्स कोड रेडियो बटन चुनें और नया प्रोग्राम बनाने के लिए Create बटन पर क्लिक करें।
Step 3- 'ABAP: प्रोग्राम एट्रीब्यूट्स' डायलॉग बॉक्स में, टाइटल फ़ील्ड में प्रोग्राम के लिए एक संक्षिप्त विवरण दर्ज करें, एट्रीब्यूट्स ग्रुप बॉक्स में टाइप ड्रॉप-डाउन मेनू से 'एक्ज़ीक्यूटेबल प्रोग्राम' विकल्प चुनें। सेव बटन पर क्लिक करें।
Step 4 - ABAP संपादक में निम्नलिखित कोड लिखें।
REPORT ZINTERNAL_DEMO.
TYPES: BEGIN OF CustomerLine,
Cust_ID TYPE C,
Cust_Name(20) TYPE C,
END OF CustomerLine.
TYPES mytable TYPE SORTED TABLE OF CustomerLine
WITH UNIQUE KEY Cust_ID.
WRITE:/'The mytable is an Internal Table'.
Step 5 - कार्यक्रम को सामान्य रूप से सहेजें, सक्रिय करें और निष्पादित करें।
इस उदाहरण में, mytable एक आंतरिक तालिका है और Cust_ID फ़ील्ड पर एक अद्वितीय कुंजी परिभाषित की गई है।
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
The mytable is an Internal Table.