COBOL - डेटाबेस इंटरफ़ेस

अब तक, हमने COBOL में फ़ाइलों का उपयोग सीखा है। अब, हम चर्चा करेंगे कि एक COBOL प्रोग्राम DB2 के साथ कैसे इंटरैक्ट करता है। इसमें निम्नलिखित शर्तें शामिल हैं -

  • एंबेडेड एसक्यूएल
  • DB2 अनुप्रयोग प्रोग्रामिंग
  • मेजबान चर
  • SQLCA
  • SQL क्वेरीज़
  • Cursors

एंबेडेड एसक्यूएल

मानक SQL कार्रवाई करने के लिए COBOL कार्यक्रमों में एंबेडेड SQL स्टेटमेंट का उपयोग किया जाता है। एंबेडेड SQL स्टेटमेंट एप्लिकेशन प्रोग्राम के संकलित होने से पहले SQL प्रोसेसर द्वारा प्रीप्रोसेस किए जाते हैं। COBOL के रूप में जाना जाता हैHost Language। COBOL-DB2 अनुप्रयोग वे अनुप्रयोग हैं जिनमें COBOL और DB2 दोनों शामिल हैं।

एंबेडेड एसक्यूएल स्टेटमेंट कुछ मामूली बदलावों के साथ सामान्य एसक्यूएल बयानों की तरह काम करते हैं। उदाहरण के लिए, एक क्वेरी के आउटपुट को चर के पूर्वनिर्धारित सेट पर निर्देशित किया जाता है, जिसे इस रूप में संदर्भित किया जाता हैHost Variables। एक अतिरिक्त INTO क्लॉज को सेलेक्ट स्टेटमेंट में रखा गया है।

DB2 अनुप्रयोग प्रोग्रामिंग

COBOL-DB2 प्रोग्राम को कोड करते समय निम्नलिखित नियमों का पालन किया जाता है -

  • सभी SQL कथनों के बीच सीमांकित किया जाना चाहिए EXEC SQL तथा ENDEXEC.

  • SQL कथन को एरिया B में कोड किया जाना चाहिए।

  • सभी तालिकाएँ जो किसी प्रोग्राम में उपयोग की जाती हैं, उन्हें वर्कस्टोरेज सेक्शन में घोषित किया जाना चाहिए। यह का उपयोग करके किया जाता है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 एक SQL संचार क्षेत्र है जिसके माध्यम से DB2 प्रोग्राम को SQL निष्पादन की प्रतिक्रिया देता है। यह कार्यक्रम को बताता है कि एक निष्पादन सफल था या नहीं। SQLCA के अंतर्गत कई पूर्वनिर्धारित चर हैंSQLCODEजिसमें त्रुटि कोड है। SQLCODE में '000' मान एक सफल निष्पादन बताता है।

वाक्य - विन्यास

वर्किंग-स्टोरेज सेक्शन में SQLCA घोषित करने का सिंटैक्स निम्नलिखित है -

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

SQL क्वेरीज़

मान लेते हैं कि हमारे पास एक स्टूडेंट है जिसका नाम स्टूडेंट-आईडी, स्टूडेंट-नेम और स्टूडेंट-एड्रेस है।

छात्र तालिका में निम्नलिखित डेटा शामिल हैं -

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

कर्सर

एक समय में कई पंक्ति चयनों को संभालने के लिए कर्सर का उपयोग किया जाता है। वे डेटा संरचनाएं हैं जो क्वेरी के सभी परिणामों को रखती हैं। उन्हें कार्य-संग्रहण अनुभाग या प्रक्रिया प्रभाग में परिभाषित किया जा सकता है। Cursor से जुड़े ऑपरेशन निम्नलिखित हैं -

  • 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.

खुला हुआ

कर्सर का उपयोग करने से पहले, ओपन स्टेटमेंट का प्रदर्शन किया जाना चाहिए। खुला बयान निष्पादन के लिए चयन तैयार करता है।

EXEC SQL
   OPEN STUDCUR
END-EXEC.

बंद करे

क्लोज स्टेटमेंट कर्सर द्वारा कब्जा की गई सभी मेमोरी को रिलीज़ करता है। प्रोग्राम खत्म करने से पहले कर्सर को बंद करना अनिवार्य है।

EXEC SQL
   CLOSE STUDCUR
END-EXEC.

लाना

फ़ॉच स्टेटमेंट कर्सर की पहचान करता है और वैल्यू को INTO क्लॉज़ में डालता है। जब हम एक बार में एक पंक्ति प्राप्त करते हैं तो एक फ़ॉच स्टेटमेंट को लूप में कोडित किया जाता है।

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

निम्न उदाहरण छात्र तालिका से सभी रिकॉर्ड लाने के लिए कर्सर के उपयोग को दर्शाता है -

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