SAP ABAP-내부 테이블 읽기
READ TABLE 문의 다음 구문을 사용하여 테이블의 행을 읽을 수 있습니다.
READ TABLE <internal_table> FROM <work_area_itab>.
이 구문에서 <work_area_itab> 표현식은 <internal_table> 테이블의 라인 유형과 호환되는 작업 영역을 나타냅니다. 다음 구문과 같이 WITH KEY 절을 사용하여 READ 문 내에서 검색 키를 지정할 수 있지만 테이블 키는 지정할 수 없습니다.
READ TABLE <internal_table> WITH KEY = <internal_tab_field>.
여기에서 내부 테이블의 전체 라인은 search key. 테이블의 전체 행 내용은 <internal_tab_field> 필드의 내용과 비교됩니다. <internal_tab_field> 필드의 값이 테이블의 라인 유형과 호환되지 않는 경우 이러한 값은 테이블의 라인 유형에 따라 변환됩니다. 검색 키를 사용하면 구조화 된 라인 유형이없는 내부 테이블, 즉 라인이 단일 필드 또는 내부 테이블 유형 인 내부 테이블에서 항목을 찾을 수 있습니다.
READ 문의 다음 구문은 COMPARING 절을 사용하여 작업 영역 또는 필드 기호를 지정하는 데 사용됩니다-
READ TABLE <internal_table> <key> INTO <work_area_itab>
[COMPARING <F1> <F2>...<Fn>].
COMPARING 절을 사용하면 구조화 된 라인 유형의 지정된 테이블 필드 <F1>, <F2> .... <Fn>이 전송되기 전에 작업 영역의 해당 필드와 비교됩니다. ALL 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은 6 줄로 채워져 있으며 ColP 필드에는 SY-INDEX 변수의 값이 포함되고 ColQ 필드에는 (SY-INDEX + 5) 값이 포함됩니다.
Record1 작업 영역은 각각 ColP 및 ColQ 필드에 대한 값으로 4와 12로 채워집니다. READ 문은 COMPARING 절을 사용하여 ColP 키 필드의 값과 Record1 작업 영역의 값을 비교 한 후 테이블의 행을 읽은 다음 읽기 행의 내용을 작업 영역에 복사합니다. ColP 필드의 값이 4이면 ColQ의 값이 12가 아니라 9이기 때문에 SY-SUBRC 변수의 값은 2로 표시됩니다.