JCL - बेस लाइब्रेरी

Base Libraryविभाजन डेटासैट (पीडीएस) है, जो जेसीएल या कैटलॉग प्रक्रिया में निष्पादित होने वाले प्रोग्राम के लोड मॉड्यूल को रखता है, जिसे प्रोग्राम में कहा जाता है। बेस लाइब्रेरीज़ को पूरे जेसीएल के लिए निर्दिष्ट किया जा सकता हैJOBLIB पुस्तकालय या किसी विशेष नौकरी के लिए कदम STEPLIB बयान।

JOBLIB स्टेटमेंट

JOBLIBJCL में निष्पादित होने वाले कार्यक्रम के स्थान की पहचान करने के लिए कथन का उपयोग किया जाता है। JOBLIB स्टेटमेंट JOB स्टेटमेंट के बाद और EXEC स्टेटमेंट से पहले निर्दिष्ट किया जाता है। इसका उपयोग केवल स्ट्रीम प्रक्रियाओं और कार्यक्रमों के लिए किया जा सकता है।

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

निम्नलिखित JCL JOBLIB स्टेटमेंट का मूल सिंटैक्स है:

//JOBLIB DD DSN=dsnname,DISP=SHR

JOBLIB बयान JCL के भीतर सभी EXEC कथनों पर लागू होता है। EXEC स्टेटमेंट में निर्दिष्ट प्रोग्राम को JOBLIB लाइब्रेरी में खोजा जाएगा जिसके बाद सिस्टम लाइब्रेरी होगी।

उदाहरण के लिए, यदि EXEC स्टेटमेंट एक COBOL प्रोग्राम को निष्पादित कर रहा है, तो COBOL प्रोग्राम के लोड मॉड्यूल को JOBLIB लाइब्रेरी के भीतर रखा जाना चाहिए।

STEPLIB स्टेटमेंट

STEPLIBकथन का उपयोग प्रोग्राम के स्थान को जॉब स्टेप के भीतर निष्पादित करने के लिए किया जाता है। STEPLIB स्टेटमेंट EXEC स्टेटमेंट के बाद और जॉब स्टेप के DD स्टेटमेंट से पहले निर्दिष्ट किया गया है।

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

निम्नलिखित JCL STEPLIB स्टेटमेंट का मूल सिंटैक्स है:

//STEPLIB DD DSN=dsnname,DISP=SHR

EXEC स्टेटमेंट में निर्दिष्ट प्रोग्राम को STEPLIB लाइब्रेरी में खोजा जाएगा, उसके बाद सिस्टम लाइब्रेरी में लाया जाएगा। जॉब स्टेप में कोड किए गए STEPLIB ने JOBLIB स्टेटमेंट को ओवरराइड किया।

उदाहरण

निम्न उदाहरण JOBLIB और STEPLIB कथनों के उपयोग को दर्शाता है:

//MYJCL JOB ,,CLASS=6,NOTIFY=&SYSUID
//*
//JOBLIB DD DSN=MYPROC.BASE.LIB1,DISP=SHR
//*
//STEP1 EXEC PGM=MYPROG1
//INPUT1 DD DSN=MYFILE.SAMPLE.INPUT1,DISP=SHR
//OUTPUT1 DD DSN=MYFILES.SAMPLE.OUTPUT1,DISP=(,CATLG,DELETE),
//           RECFM=FB,LRECL=80
//*
//STEP2 EXEC PGM=MYPROG2
//STEPLIB DD DSN=MYPROC.BASE.LIB2,DISP=SHR
//INPUT2 DD DSN=MYFILE.SAMPLE.INPUT2,DISP=SHR
//OUTPUT2 DD DSN=MYFILES.SAMPLE.OUTPUT2,DISP=(,CATLG,DELETE),
//           RECFM=FB,LRECL=80

यहाँ, MYPROG1 (STEP1 में) प्रोग्राम का लोड मॉड्यूल MYPROC.SAMPLE.LIB1 में खोजा गया है। यदि नहीं मिला है, तो इसे सिस्टम लाइब्रेरी में खोजा जाता है। STEP2 में, STEPLIB JOBLIB को ओवरराइड करता है और MYPROG2 प्रोग्राम के लोड मॉड्यूल को MYPROC.SAMPLE.LIB2 और फिर सिस्टम लाइब्रेरी में खोजा जाता है।

INCLUDE स्टेटमेंट

एक पीडीएस के एक सदस्य के भीतर कोडित जेसीएल बयानों के एक सेट को जेसीएल का उपयोग करके शामिल किया जा सकता है INCLUDEबयान। जब JES JCL की व्याख्या करता है, तो INCLUDE सदस्य के भीतर JCL कथनों का सेट INCLUDE कथन को बदल देता है।

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

JCL INCLUDE स्टेटमेंट का मूल सिंटैक्स निम्नलिखित है:

//name INCLUDE MEMBER=member-name

INCLUDE कथन का मुख्य उद्देश्य पुन: प्रयोज्य है। उदाहरण के लिए, कई JCLs में उपयोग की जाने वाली आम फ़ाइलों को INCLUDE सदस्य के भीतर DD स्टेटमेंट के रूप में कोडित किया जा सकता है और JCL में उपयोग किया जा सकता है।

डमी डीडी स्टेटमेंट्स, डेटा कार्ड स्पेसिफिकेशन्स, PROCs, JOB, PROC स्टेटमेंट्स को INCLUDE सदस्य के भीतर कोड नहीं किया जा सकता है। एक INLCUDE विवरण को INCLUDE सदस्य के भीतर कोडित किया जा सकता है और आगे के घोंसले का शिकार 15 स्तरों तक किया जा सकता है।

JCLLIB स्टेटमेंट

JCLLIBबयान का इस्तेमाल नौकरी में इस्तेमाल होने वाले निजी पुस्तकालयों की पहचान करने के लिए किया जाता है। इसे इंस्ट्रूम और कैटलॉग प्रक्रियाओं के साथ इस्तेमाल किया जा सकता है।

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

JCL JCLLIB स्टेटमेंट का मूल सिंटैक्स निम्नलिखित है:

//name JCLLIB ORDER=(library1, library2....)

JCLLIB विवरण में निर्दिष्ट पुस्तकालयों को कार्य में उपयोग किए जाने वाले कार्यक्रमों, प्रक्रियाओं और INCLUDE सदस्य का पता लगाने के लिए दिए गए क्रम में खोजा जाएगा। एक JCL में केवल एक JCLLIB स्टेटमेंट हो सकता है; एक JOB स्टेटमेंट के बाद और EXEC और INCLUDE स्टेटमेंट के बाद निर्दिष्ट किया गया है लेकिन इसे INCLUDE सदस्य के भीतर कोड नहीं किया जा सकता है।

उदाहरण

निम्नलिखित उदाहरण में, प्रोग्राम MYPROG3 और INCLUDE सदस्य MYINCL को MYPROC.BASE.LIB1, MYPROC.BASE.LIB2, सिस्टम लाइब्रेरी के क्रम में खोजा गया है।

//MYJCL JOB ,,CLASS=6,NOTIFY=&SYSUID
//*
//MYLIB JCLLIB ORDER=(MYPROC.BASE.LIB1,MYPROC.BASE.LIB2)
//*
//STEP1 EXEC PGM=MYPROG3
//INC INCLUDE MEMBER=MYINCL
//OUTPUT1 DD DSN=MYFILES.SAMPLE.OUTPUT1,DISP=(,CATLG,DELETE),
//           RECFM=FB,LRECL=80
//*