COBOL-데이터베이스 인터페이스

지금까지 COBOL에서 파일 사용을 배웠습니다. 이제 COBOL 프로그램이 DB2와 상호 작용하는 방법에 대해 설명합니다. 그것은 다음 용어를 포함합니다-

  • 임베디드 SQL
  • DB2 애플리케이션 프로그래밍
  • 호스트 변수
  • SQLCA
  • SQL 쿼리
  • Cursors

임베디드 SQL

Embedded SQL 문은 표준 SQL 조작을 수행하기 위해 COBOL 프로그램에서 사용됩니다. Embedded SQL 문은 애플리케이션 프로그램이 컴파일되기 전에 SQL 프로세서에 의해 사전 처리됩니다. COBOL은Host Language. COBOL-DB2 애플리케이션은 COBOL과 DB2를 모두 포함하는 애플리케이션입니다.

Embedded SQL 문은 약간의 변경이있는 일반 SQL 문처럼 작동합니다. 예를 들어, 쿼리의 출력은 다음과 같은 사전 정의 된 변수 세트로 전달됩니다.Host Variables. 추가 INTO 절이 SELECT 문에 배치됩니다.

DB2 애플리케이션 프로그래밍

다음은 COBOL-DB2 프로그램을 코딩하는 동안 따라야 할 규칙입니다.

  • 모든 SQL 문은 EXEC SQLENDEXEC..

  • SQL 문은 영역 B에서 코딩되어야합니다.

  • 프로그램에서 사용되는 모든 테이블은 WorkingStorage 섹션에서 선언되어야합니다. 이것은INCLUDE 성명서.

  • INCLUDE 및 DECLARE TABLE을 제외한 모든 SQL 문은 프로 시저 분할에 나타나야합니다.

호스트 변수

호스트 변수는 테이블에서 데이터를 받거나 테이블에 데이터를 삽입하는 데 사용됩니다. 프로그램과 DB2간에 전달되는 모든 값에 대해 호스트 변수를 선언해야합니다. 이들은 작업 저장 섹션에서 선언됩니다.

호스트 변수는 그룹 항목이 될 수 없지만 호스트 구조에서 함께 그룹화 될 수 있습니다. 그들은 될 수 없습니다Renamed 또는 Redefined. SQL 문에 호스트 변수를 사용하여colon (:)..

통사론

다음은 호스트 변수를 선언하고 작업 스토리지 섹션에 테이블을 포함하는 구문입니다.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE table-name
   END-EXEC.

   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
   
   01 STUDENT-REC.
      05 STUDENT-ID PIC 9(4).
      05 STUDENT-NAME PIC X(25).
      05 STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

SQLCA

SQLCA는 DB2가 SQL 실행 피드백을 프로그램에 전달하는 SQL 통신 영역입니다. 실행의 성공 여부를 프로그램에 알려줍니다. SQLCA에는 다음과 같은 사전 정의 된 변수가 많이 있습니다.SQLCODE오류 코드가 포함되어 있습니다. SQLCODE의 값 '000'은 성공적인 실행을 나타냅니다.

통사론

다음은 Working-Storage 섹션에서 SQLCA를 선언하는 구문입니다.

DATA DIVISION.
WORKING-STORAGE SECTION.
	EXEC SQL
	INCLUDE SQLCA
	END-EXEC.

SQL 쿼리

Student-Id, Student-Name 및 Student-Address가 포함 된 'Student'라는 이름의 테이블이 있다고 가정 해 보겠습니다.

STUDENT 테이블은 다음 데이터를 포함합니다-

Student Id		Student Name		Student Address
1001 			   Mohtashim M.		Hyderabad
1002			   Nishant Malik		Delhi
1003 			   Amitabh Bachan		Mumbai
1004			   Chulbul Pandey		Lucknow

다음 예는 SELECT COBOL 프로그램에서 쿼리-

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   EXEC SQL
      INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
      INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   EXEC SQL
      SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS
      INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS FROM STUDENT
      WHERE STUDENT-ID=1004
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY WS-STUDENT-RECORD
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL 위의 COBOL 프로그램을 실행하려면-

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP = SHR
//SYSPRINT DD SYSOUT=*
//SYSUDUMP DD SYSOUT=*
//SYSOUT   DD SYSOUT=*
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

1004 Chulbul Pandey		Lucknow

다음 예는 INSERT COBOL 프로그램에서 쿼리-

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1005 TO WS-STUDENT-ID.
   MOVE 'TutorialsPoint' TO WS-STUDENT-NAME.
   MOVE 'Hyderabad' TO WS-STUDENT-ADDRESS.
   
   EXEC SQL
      INSERT INTO STUDENT(STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS)
      VALUES (:WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS)
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Inserted Successfully'
      DISPLAY WS-STUDENT-REC
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL 위의 COBOL 프로그램을 실행하려면-

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Record Inserted Successfully
1005 TutorialsPoint		Hyderabad

다음 예는 UPDATE COBOL 프로그램에서 쿼리-

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 'Bangalore' TO WS-STUDENT-ADDRESS.
   EXEC SQL
      UPDATE STUDENT SET STUDENT-ADDRESS=:WS-STUDENT-ADDRESS
      WHERE STUDENT-ID = 1003
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Updated Successfully'
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL 위의 COBOL 프로그램을 실행하려면-

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP = SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Record Updated Successfully

다음과 같은 example 사용법을 보여줍니다 DELETE COBOL 프로그램에서 쿼리-

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
WORKING-STORAGE SECTION.

   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1005 TO WS-STUDENT-ID.
   
   EXEC SQL
      DELETE FROM STUDENT
      WHERE STUDENT-ID=:WS-STUDENT-ID
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Deleted Successfully'
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL 위의 COBOL 프로그램을 실행하려면-

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Record Deleted Successfully

커서

커서는 한 번에 여러 행 선택을 처리하는 데 사용됩니다. 쿼리의 모든 결과를 보유하는 데이터 구조입니다. 작업 저장 섹션 또는 절차 부서에서 정의 할 수 있습니다. 다음은 커서와 관련된 작업입니다-

  • Declare
  • Open
  • Close
  • Fetch

커서 선언

커서 선언은 작업 보관 부서 또는 절차 부서에서 할 수 있습니다. 첫 번째 명령문은 실행 불가능한 명령문 인 DECLARE 명령문입니다.

EXEC SQL
   DECLARE STUDCUR CURSOR FOR
   SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS FROM STUDENT
   WHERE STUDENT-ID >:WS-STUDENT-ID
END-EXEC.

열다

커서를 사용하기 전에 Open 문을 수행해야합니다. Open 문은 실행을 위해 SELECT를 준비합니다.

EXEC SQL
   OPEN STUDCUR
END-EXEC.

닫기

Close 문은 커서가 차지하는 모든 메모리를 해제합니다. 프로그램을 종료하기 전에 커서를 닫아야합니다.

EXEC SQL
   CLOSE STUDCUR
END-EXEC.

술책

Fetch 문은 커서를 식별하고 값을 INTO 절에 넣습니다. Fetch 문은 한 번에 하나의 행을 가져 오므로 루프로 코딩됩니다.

EXEC SQL
   FETCH STUDCUR
   INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS
END-EXEC.

다음 예는 커서를 사용하여 STUDENT 테이블에서 모든 레코드를 가져 오는 방법을 보여줍니다.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.
   
   EXEC SQL
      DECLARE STUDCUR CURSOR FOR
      SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS FROM STUDENT
      WHERE STUDENT-ID >:WS-STUDENT-ID
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1001 TO WS-STUDENT-ID.
   PERFORM UNTIL SQLCODE = 100
   
   EXEC SQL
      FETCH STUDCUR
      INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS
   END-EXEC
   
   DISPLAY WS-STUDENT-REC
END-PERFORM	
STOP RUN.

JCL 위의 COBOL 프로그램을 실행하려면-

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM=IKJEFT01
//STEPLIB  DD DSN=MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT=*
//SYSUDUMP DD SYSOUT=*
//SYSOUT   DD SYSOUT=*
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

1001 Mohtashim M.		Hyderabad
1002 Nishant Malik		Delhi
1003 Amitabh Bachan		Mumbai
1004 Chulbul Pandey		Lucknow