COBOL-테이블 처리
COBOL의 배열을 테이블이라고합니다. 배열은 선형 데이터 구조이며 동일한 유형의 개별 데이터 항목 모음입니다. 테이블의 데이터 항목은 내부적으로 정렬됩니다.
테이블 선언
테이블은 데이터 분할에서 선언됩니다. Occurs절은 테이블을 정의하는 데 사용됩니다. Occurs 절은 데이터 이름 정의의 반복을 나타냅니다. 02부터 49까지의 레벨 번호로만 사용할 수 있습니다. Reefines와 함께 발생 절을 사용하지 마십시오. 1 차원 및 2 차원 테이블에 대한 설명은 다음과 같습니다.
1 차원 표
1 차원 테이블에서 occurs절은 선언에서 한 번만 사용됩니다. WSTABLE은 테이블을 포함하는 그룹 항목입니다. WS-B는 10 번 발생하는 테이블 요소의 이름을 지정합니다.
Syntax
다음은 1 차원 테이블을 정의하는 구문입니다.
01 WS-TABLE.
05 WS-A PIC A(10) OCCURS 10 TIMES.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A PIC A(10) VALUE 'TUTORIALS' OCCURS 5 TIMES.
PROCEDURE DIVISION.
DISPLAY "ONE-D TABLE : "WS-TABLE.
STOP RUN.
JCL 위의 COBOL 프로그램을 실행하려면-
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
ONE-D TABLE : TUTORIALS TUTORIALS TUTORIALS TUTORIALS TUTORIALS
2 차원 표
두 데이터 요소가 가변 길이 인 2 차원 테이블이 생성됩니다. 참고로 구문을 살펴본 다음 표를 분석해보십시오. 첫 번째 어레이 (WS-A)는 1 ~ 10 회 발생할 수 있으며 내부 어레이 (WS-C)는 1 ~ 5 회 발생할 수 있습니다. WS-A의 각 항목에 대해 해당하는 WS-C 항목 5 개가 있습니다.
Syntax
다음은 2 차원 테이블을 정의하는 구문입니다.
01 WS-TABLE.
05 WS-A OCCURS 10 TIMES.
10 WS-B PIC A(10).
10 WS-C OCCURS 5 TIMES.
15 WS-D PIC X(6).
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 2 TIMES.
10 WS-B PIC A(10) VALUE ' TUTORIALS'.
10 WS-C OCCURS 2 TIMES.
15 WS-D PIC X(6) VALUE ' POINT'.
PROCEDURE DIVISION.
DISPLAY "TWO-D TABLE : "WS-TABLE.
STOP RUN.
JCL 위의 COBOL 프로그램을 실행하려면-
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
TWO-D TABLE : TUTORIALS POINT POINT TUTORIALS POINT POINT
아래 첨자
테이블 개별 요소는 아래 첨자를 사용하여 액세스 할 수 있습니다. 아래 첨자 값의 범위는 1에서 테이블 발생 횟수까지입니다. 아래 첨자는 모든 양수일 수 있습니다. 데이터 분할에서 선언 할 필요가 없습니다. 발생 절로 자동 생성됩니다.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
DISPLAY 'WS-TABLE : ' WS-TABLE.
DISPLAY 'WS-A(1) : ' WS-A(1).
DISPLAY 'WS-C(1,1) : ' WS-C(1,1).
DISPLAY 'WS-C(1,2) : ' WS-C(1,2).
DISPLAY 'WS-A(2) : ' WS-A(2).
DISPLAY 'WS-C(2,1) : ' WS-C(2,1).
DISPLAY 'WS-C(2,2) : ' WS-C(2,2).
DISPLAY 'WS-A(3) : ' WS-A(3).
DISPLAY 'WS-C(3,1) : ' WS-C(3,1).
DISPLAY 'WS-C(3,2) : ' WS-C(3,2).
STOP RUN.
JCL 위의 COBOL 프로그램을 실행하려면-
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
WS-TABLE : 12ABCDEF34GHIJKL56MNOPQR
WS-A(1) : 12ABCDEF
WS-C(1,1) : ABC
WS-C(1,2) : DEF
WS-A(2) : 34GHIJKL
WS-C(2,1) : GHI
WS-C(2,2) : JKL
WS-A(3) : 56MNOPQR
WS-C(3,1) : MNO
WS-C(3,2) : PQR
인덱스
인덱스를 사용하여 테이블 요소에 액세스 할 수도 있습니다. 인덱스는 테이블의 시작 부분에서 요소의 변위입니다. 인덱스는 INDEXED BY 절을 사용하여 Occurs 절로 선언됩니다. 인덱스 값은 SET 문과 PERFORM Varying 옵션을 사용하여 변경할 수 있습니다.
Syntax
다음은 테이블에 인덱스를 정의하는 구문입니다-
01 WS-TABLE.
05 WS-A PIC A(10) OCCURS 10 TIMES INDEXED BY I.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES INDEXED BY I.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES INDEXED BY J.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
PERFORM A-PARA VARYING I FROM 1 BY 1 UNTIL I >3
STOP RUN.
A-PARA.
PERFORM C-PARA VARYING J FROM 1 BY 1 UNTIL J>2.
C-PARA.
DISPLAY WS-C(I,J).
JCL 위의 COBOL 프로그램을 실행하려면-
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
ABC
DEF
GHI
JKL
MNO
PQR
Set 문
Set 문은 인덱스 값을 변경하는 데 사용됩니다. Set 동사는 인덱스 값을 초기화, 증가 또는 감소시키는 데 사용됩니다. 테이블에서 요소를 찾기 위해 검색 및 모두 검색과 함께 사용됩니다.
Syntax
다음은 Set 문을 사용하는 구문입니다-
SET I J TO positive-number
SET I TO J
SET I TO 5
SET I J UP BY 1
SET J DOWN BY 5
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES INDEXED BY I.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES INDEXED BY J.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
SET I J TO 1.
DISPLAY WS-C(I,J).
SET I J UP BY 1.
DISPLAY WS-C(I,J).
STOP RUN.
JCL 위의 COBOL 프로그램을 실행합니다.
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
ABC
JKL
검색
검색은 테이블 내부의 요소를 찾는 데 사용되는 선형 검색 방법입니다. 정렬 된 테이블과 정렬되지 않은 테이블에서 수행 할 수 있습니다. Index 구문으로 선언 된 테이블에만 사용됩니다. index의 초기 값으로 시작합니다. 검색된 요소를 찾지 못하면 인덱스가 자동으로 1 씩 증가하고 테이블 끝까지 계속됩니다.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A PIC X(1) OCCURS 18 TIMES INDEXED BY I.
01 WS-SRCH PIC A(1) VALUE 'M'.
PROCEDURE DIVISION.
MOVE 'ABCDEFGHIJKLMNOPQR' TO WS-TABLE.
SET I TO 1.
SEARCH WS-A
AT END DISPLAY 'M NOT FOUND IN TABLE'
WHEN WS-A(I) = WS-SRCH
DISPLAY 'LETTER M FOUND IN TABLE'
END-SEARCH.
STOP RUN.
JCL 위의 COBOL 프로그램을 실행합니다.
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
LETTER M FOUND IN TABLE
모두 검색
모두 검색은 테이블 내부의 요소를 찾는 데 사용되는 이진 검색 방법입니다. 모두 검색 옵션의 경우 테이블이 정렬 된 순서 여야합니다. 인덱스는 초기화가 필요하지 않습니다. 이진 검색에서 테이블은 두 개의 절반으로 나뉘며 검색된 요소의 절반이 존재하는지 결정합니다. 이 프로세스는 요소를 찾거나 끝에 도달 할 때까지 반복됩니다.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-RECORD OCCURS 10 TIMES ASCENDING KEY IS WS-NUM INDEXED BY I.
10 WS-NUM PIC 9(2).
10 WS-NAME PIC A(3).
PROCEDURE DIVISION.
MOVE '12ABC56DEF34GHI78JKL93MNO11PQR' TO WS-TABLE.
SEARCH ALL WS-RECORD
AT END DISPLAY 'RECORD NOT FOUND'
WHEN WS-NUM(I) = 93
DISPLAY 'RECORD FOUND '
DISPLAY WS-NUM(I)
DISPLAY WS-NAME(I)
END-SEARCH.
JCL 위의 COBOL 프로그램을 실행하려면-
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
RECORD FOUND
93
MNO