इनपुट-आउटपुट के तरीके
जेसीएल के माध्यम से निष्पादित किसी भी बैच प्रोग्राम को डेटा इनपुट की आवश्यकता होती है, जिसे संसाधित किया जाता है और एक आउटपुट बनाया जाता है। एक जेसीएल से प्राप्त कार्यक्रम और लेखन आउटपुट को इनपुट करने के विभिन्न तरीके हैं। बैच मोड में, कोई उपयोगकर्ता सहभागिता आवश्यक नहीं है, लेकिन इनपुट और आउटपुट डिवाइस और आवश्यक संगठन को जेसीएल में परिभाषित किया गया है और प्रस्तुत किया गया है।
एक JCL में डेटा इनपुट
JCL का उपयोग करके किसी प्रोग्राम को डेटा फीड करने के विभिन्न तरीके हैं और इन तरीकों को नीचे समझाया गया है:
INSTREAM डेटा
एक प्रोग्राम के लिए डेटा को SYSIN DD स्टेटमेंट का उपयोग करके निर्दिष्ट किया जा सकता है।
//CONCATEX JOB CLASS=6,NOTIFY=&SYSUID
//* Example 1:
//STEP10 EXEC PGM=MYPROG
//IN1 DD DSN=SAMPLE.INPUT1,DISP=SHR
//OUT1 DD DSN=SAMPLE.OUTPUT1,DISP=(,CATLG,DELETE),
// LRECL=50,RECFM=FB
//SYSIN DD *
//CUST1 1000
//CUST2 1001
/*
//*
//* Example 2:
//STEP20 EXEC PGM=MYPROG
//OUT1 DD DSN=SAMPLE.OUTPUT2,DISP=(,CATLG,DELETE),
// LRECL=50,RECFM=FB
//SYSIN DD DSN=SAMPLE.SYSIN.DATA,DISP=SHR
//*
उदाहरण 1 में, MYPROG का इनपुट SYSIN से होकर गुजरा है। डेटा JCL के भीतर प्रदान किया जाता है। कार्यक्रम में डेटा के दो रिकॉर्ड पारित किए जाते हैं। कृपया ध्यान दें कि / * इंस्टेंस SYSIN डेटा के अंत को चिह्नित करता है।
"CUST1 1000" रिकॉर्ड 1 है और "CUST2 1001" रिकॉर्ड 2 है। डेटा स्थिति का अंत तब मिलता है जब डेटा पढ़ते समय प्रतीक / * का सामना किया जाता है।
उदाहरण 2 में, SYSIN डेटा एक डेटासेट के भीतर आयोजित किया जाता है, जहां SAMPLE.SYSIN.DATA एक PS फ़ाइल है, जो डेटा का एक या अधिक रिकॉर्ड रख सकता है।
फ़ाइलों के माध्यम से डेटा इनपुट
जैसा कि पिछले अध्यायों में अधिकांश उदाहरणों में उल्लेख किया गया है, प्रोग्राम के डेटा इनपुट को PS, VSAM या GDG फ़ाइलों के माध्यम से प्रासंगिक DSN नाम और DISP मापदंडों के साथ DD स्टेटमेंट के माध्यम से प्रदान किया जा सकता है।
उदाहरण 1 में, SAMPLE.INPUT1 इनपुट फ़ाइल है, जिसके माध्यम से MYPROG को डेटा पास किया जाता है। इसे कार्यक्रम के भीतर IN1 के रूप में संदर्भित किया जाता है।
एक JCL में डेटा आउटपुट
JCL में आउटपुट को डेटासेट में सूचीबद्ध किया जा सकता है या SYSOUT को पास किया जा सकता है। जैसा कि डीडी स्टेटमेंट चैप्टर में बताया गया है,SYSOUT=* JOB स्टेटमेंट के MSGCLASS पैरामीटर में उल्लिखित उसी वर्ग के आउटपुट को रीडायरेक्ट करता है।
सेविंग जॉब लॉग्स
निर्दिष्ट करना MSGCLASS=YJMR (जॉबब्लॉग मैनेजमेंट एंड रिट्रीवल) में जॉब लॉग बचाता है। पूरे JOB लॉग को SPOOL पर पुनर्निर्देशित किया जा सकता है और एक डेटासेट को बचाया जा सकता है देकर SPOOL में नौकरी के नाम के खिलाफ XDCAM कमांड दी जाती है। जब XDCAM आदेश SPOOL में दिया जाता है, तो एक डेटासेट निर्माण स्क्रीन खोला जाता है। नौकरी लॉग को तब उचित पीएस या पीडीएस परिभाषा देकर बचाया जा सकता है।
नौकरी लॉग को SYSOUT और SYSPRINT के लिए पहले से ही बनाए गए डेटासेट का उल्लेख करके डेटासेट में सहेजा जा सकता है। लेकिन पूरे जॉब लॉग को इस तरह से कैप्चर नहीं किया जा सकता (जैसे, JESMSG को कैटलॉग नहीं किया जाएगा) जैसा कि JMR या XDCAM में किया गया है।
//SAMPINST JOB 1,CLASS=6,MSGCLASS=Y,NOTIFY=&SYSUID
//*
//STEP1 EXEC PGM=MYPROG
//IN1 DD DSN=MYDATA.URMI.INPUT,DISP=SHR
//OUT1 DD SYSOUT=*
//SYSOUT DD DSN=MYDATA.URMI.SYSOUT,DISP=SHR
//SYSPRINT DD DSN=MYDATA.URMI.SYSPRINT,DISP=SHR
//SYSIN DD MYDATA.BASE.LIB1(DATA1),DISP=SHR
//*
//STEP2 EXEC PGM=SORT
उपरोक्त उदाहरण में, SYSOUT को MYDATA.URMI.SYSOUT और SYSPRINT को MYDATA.URMI.SYSPRINT में सूचीबद्ध किया गया है।