SAP ABAP - आंतरिक तालिकाओं को पढ़ना

READ TABLE स्टेटमेंट के निम्नलिखित सिंटैक्स का उपयोग करके हम एक तालिका की पंक्तियों को पढ़ सकते हैं -

READ TABLE <internal_table> FROM <work_area_itab>.

इस सिंटैक्स में, <work_area_itab> अभिव्यक्ति एक कार्य क्षेत्र का प्रतिनिधित्व करती है जो लाइन के प्रकार के साथ संगत है <internal_table> तालिका। हम एक खोज कुंजी निर्दिष्ट कर सकते हैं, लेकिन तालिका कुंजी नहीं, READ कथन के साथ, कुंजी खंड का उपयोग करके, जैसा कि निम्नलिखित सिंटैक्स में दिखाया गया है -

READ TABLE <internal_table> WITH KEY = <internal_tab_field>.

यहां आंतरिक तालिका की पूरी पंक्ति का उपयोग किया जाता है search key। तालिका की संपूर्ण पंक्ति की सामग्री की तुलना <internal_tab_field> फ़ील्ड की सामग्री से की जाती है। यदि <आंतरिक_टैब_फ़ील्ड> फ़ील्ड के मान तालिका प्रकार की पंक्ति के अनुरूप नहीं हैं, तो ये मान तालिका के पंक्ति प्रकार के अनुसार परिवर्तित हो जाते हैं। खोज कुंजी आपको आंतरिक तालिकाओं में प्रविष्टियां खोजने की अनुमति देती है, जिसमें एक संरचित रेखा प्रकार नहीं होता है, अर्थात जहां रेखा एकल फ़ील्ड या आंतरिक तालिका प्रकार है।

READ स्टेटमेंट के निम्नलिखित सिंटैक्स का उपयोग कंप्रेशन क्लॉज का उपयोग करके किसी कार्य क्षेत्र या फील्ड सिंबल को निर्दिष्ट करने के लिए किया जाता है -

READ TABLE <internal_table> <key> INTO <work_area_itab>
   [COMPARING <F1> <F2>...<Fn>].

जब कंपोज़िंग क्लॉज़ का उपयोग किया जाता है, तो निर्दिष्ट लाइन फ़ील्ड्स <F1>, <F2> .... <संरचित लाइन प्रकार के Fn को परिवहन किए जाने से पहले कार्य क्षेत्र के संबंधित क्षेत्रों के साथ तुलना की जाती है। यदि सभी FIELDS क्लॉज निर्दिष्ट है, तो SAP सिस्टम सभी घटकों की तुलना करता है। जब SAP सिस्टम एक कुंजी के आधार पर एक प्रविष्टि पाता है, SY-SUBRC चर का मान 0. पर सेट होता है। इसके अलावा, SY-SUBRC चर का मान 2 या 4 पर सेट किया जाता है यदि तुलना की गई सामग्री फ़ील्ड समान नहीं हैं या यदि SAP सिस्टम प्रविष्टि नहीं पा सकता है। हालाँकि, SAP सिस्टम लक्ष्य कार्य क्षेत्र में प्रविष्टि की प्रतिलिपि बनाता है, जब भी यह तुलना के परिणाम की परवाह किए बिना प्रविष्टि पाता है।

उदाहरण

REPORT  ZREAD_DEMO. 
*/Creating an internal table 
DATA: BEGIN OF Record1, 
ColP TYPE I, 
ColQ TYPE I, 
END OF Record1. 

DATA mytable LIKE HASHED TABLE OF Record1 WITH UNIQUE KEY ColP. 
DO 6 Times.
Record1-ColP = SY-INDEX. 
Record1-ColQ = SY-INDEX + 5. 
INSERT Record1 INTO TABLE mytable. 
ENDDO. 

Record1-ColP = 4. 
Record1-ColQ = 12. 
READ TABLE mytable FROM Record1 INTO Record1 COMPARING ColQ. 

WRITE: 'SY-SUBRC =', SY-SUBRC. 
SKIP. 
WRITE: / Record1-ColP, Record1-ColQ.

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

SY-SUBRC =    2 

4         9

उपरोक्त उदाहरण में, mytable हैशेड टेबल प्रकार की एक आंतरिक तालिका है, जिसमें कार्य क्षेत्र के रूप में Record1 और अद्वितीय कुंजी के रूप में ColP है। प्रारंभ में, mytable छह लाइनों के साथ आबाद है, जहां ColP फ़ील्ड में SY-INDEX चर के मान शामिल हैं और ColQ फ़ील्ड में (SY-INDEX + 5) मान हैं।

रिकॉर्ड 1 कार्य क्षेत्र 4 और 12 के साथ क्रमशः ColP और ColQ फ़ील्ड के मानों के साथ आबाद है। READ स्टेटमेंट, तालिका 1 की तालिका को पढ़ने के बाद ColP कुंजी क्षेत्र के मान की तुलना Record1 कार्य क्षेत्र में COMPARING क्लॉज का उपयोग करके करता है, और फिर कार्य क्षेत्र में रीड लाइन की सामग्री की प्रतिलिपि बनाता है। SY-SUBRC चर का मान 2 के रूप में प्रदर्शित होता है क्योंकि जब ColP फ़ील्ड में मान 4 होता है, तो ColQ में मान 12 नहीं, बल्कि 9 होता है।