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 कथन के साथ किया गया है।