SAP ABAP - आंतरिक तालिकाओं की प्रतिलिपि बनाना
जब हम हेडर लाइन के साथ एक आंतरिक तालिका से एक रिकॉर्ड पढ़ते हैं, तो उस रिकॉर्ड को तालिका से हेडर लाइन में स्थानांतरित किया जाता है। यह तब हेडर लाइन है जिसके साथ हमारा प्रोग्राम काम करता है। नया रिकॉर्ड बनाते समय भी यही बात लागू होती है। यह हेडर लाइन है जिसके साथ आप काम करते हैं और जिससे नया रिकॉर्ड टेबल बॉडी को ही भेजा जाता है।
अभिलेखों की प्रतिलिपि बनाने के लिए, हम तालिका से सभी अभिलेखों का चयन करने के लिए एक सेलेक्ट स्टेटमेंट का उपयोग कर सकते हैं और फिर MOVE स्टेटमेंट का उपयोग कर सकते हैं जो रिकॉर्ड्स को मूल आंतरिक तालिका से नई आंतरिक तालिका में उन क्षेत्रों में स्थानांतरित कर देगा जहां नाम अनुरूप हैं।
निम्नलिखित MOVE बयान के लिए वाक्य रचना है -
MOVE <table_field> TO <internal_tab_field>.
उदाहरण
REPORT ZCUSLIST1.
TABLES: ZCUSTOMERS1.
DATA: BEGIN OF itab01 Occurs 0,
name LIKE ZCUSTOMERS1-name,
dob LIKE ZCUSTOMERS1-dob,
END OF itab01.
Select * FROM ZCUSTOMERS1.
MOVE ZCUSTOMERS1-name TO itab01-name.
MOVE ZCUSTOMERS1-dob TO itab01-dob.
ENDSELECT.
Write: / itab01-name, itab01-dob.
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
MARGARET 02.11.1994
चुनिंदा लूप एक समय में प्रत्येक फ़ील्ड को भरता है, एक तालिका के फ़ील्ड से दूसरे में डेटा स्थानांतरित करने के लिए MOVE स्टेटमेंट का उपयोग करता है। ऊपर दिए गए उदाहरण में, MOVE कथनों का उपयोग ZCUSTOMERS1 तालिका की सामग्री को आंतरिक तालिका में संबंधित फ़ील्ड में ले जाने के लिए किया गया था। आप इस क्रिया को कोड की केवल एक पंक्ति के साथ पूरा कर सकते हैं। आप MOVECORRESPONDING स्टेटमेंट का उपयोग कर सकते हैं।
MOVE-CORRESPONDING स्टेटमेंट के लिए वाक्य रचना निम्नलिखित है -
MOVE-CORRESPONDING <table_name> TO <internal_tab>.
यह प्रणाली को ZCUSTOMERS1 के क्षेत्रों से डेटा को itab01 में उनके संबंधित क्षेत्रों में स्थानांतरित करने के लिए कहता है।
उदाहरण
REPORT ZCUSTOMERLIST.
TABLES: ZCUSTOMERS1.
DATA: Begin of itab01 occurs 0,
customer LIKE ZCUSTOMERS1-customer,
name LIKE ZCUSTOMERS1-name,
title LIKE ZCUSTOMERS1-title,
dob LIKE ZCUSTOMERS1-dob,
END OF itab01.
SELECT * from ZCUSTOMERS1.
MOVE-Corresponding ZCUSTOMERS1 TO itab01.
APPEND itab01.
ENDSELECT.
LOOP AT itab01.
Write: / itab01-name, itab01-dob.
ENDLOOP.
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
MARK 21.05.1981
JAMES 14.08.1977
AURIELE 19.06.1990
STEPHEN 22.07.1985
MARGARET 02.11.1994
यह इस तथ्य से संभव हो जाता है कि दोनों में मेल खाने वाले क्षेत्र के नाम हैं। इस कथन का उपयोग करते समय, आपको यह सुनिश्चित करने की आवश्यकता है कि दोनों फ़ील्ड में डेटा प्रकार और लंबाई मिलान है। यह यहाँ पहले LIKE कथन के साथ किया गया है।