इनपुट-आउटपुट के तरीके

जेसीएल के माध्यम से निष्पादित किसी भी बैच प्रोग्राम को डेटा इनपुट की आवश्यकता होती है, जिसे संसाधित किया जाता है और एक आउटपुट बनाया जाता है। एक जेसीएल से प्राप्त कार्यक्रम और लेखन आउटपुट को इनपुट करने के विभिन्न तरीके हैं। बैच मोड में, कोई उपयोगकर्ता सहभागिता आवश्यक नहीं है, लेकिन इनपुट और आउटपुट डिवाइस और आवश्यक संगठन को जेसीएल में परिभाषित किया गया है और प्रस्तुत किया गया है।

एक 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 में सूचीबद्ध किया गया है।