JCL - Mendefinisikan Set Data

Nama set data menentukan nama file dan dilambangkan dengan DSN di JCL. Parameter DSN mengacu pada nama dataset fisik dari dataset yang baru dibuat atau yang sudah ada. Nilai DSN dapat terdiri dari sub-nama yang masing-masing memiliki panjang 1 hingga 8 karakter, dipisahkan oleh titik dan dengan total panjang 44 karakter (alfanumerik). Berikut sintaksnya:

DSN=&name | *.stepname.ddname

Temporary datasetsperlu penyimpanan hanya selama durasi pekerjaan dan dihapus saat pekerjaan selesai. Kumpulan data tersebut direpresentasikan sebagaiDSN=&name atau hanya tanpa DSN yang ditentukan.

Jika kumpulan data sementara yang dibuat oleh langkah pekerjaan akan digunakan di langkah pekerjaan berikutnya, maka itu direferensikan sebagai DSN=*.stepname.ddname. Ini disebutBackward Referencing.

Kumpulan Data Gabungan

Jika ada lebih dari satu dataset dengan format yang sama, mereka dapat digabungkan dan diteruskan sebagai input ke program dalam satu nama DD.

//CONCATEX JOB CLASS=6,NOTIFY=&SYSUID
//*
//STEP10    EXEC PGM=SORT
//SORTIN    DD DSN=SAMPLE.INPUT1,DISP=SHR
//          DD DSN=SAMPLE.INPUT2,DISP=SHR
//          DD DSN=SAMPLE.INPUT3,DISP=SHR
//SORTOUT   DD DSN=SAMPLE.OUTPUT,DISP=(,CATLG,DELETE),
//          LRECL=50,RECFM=FB

Dalam contoh di atas, tiga dataset digabungkan dan diteruskan sebagai input ke program SORT dalam nama SORTIN DD. File digabungkan, diurutkan pada bidang kunci yang ditentukan dan kemudian ditulis ke satu file output SAMPLE.OUTPUT dalam nama SORTOUT DD.

Mengganti Set Data

Dalam JCL standar, program yang akan dijalankan dan kumpulan data terkait ditempatkan dalam prosedur katalog, yang disebut dalam JCL. Biasanya, untuk tujuan pengujian atau untuk perbaikan insiden, mungkin ada kebutuhan untuk menggunakan kumpulan data yang berbeda selain yang ditentukan dalam prosedur katalog. Dalam hal ini, set data dalam prosedur dapat diganti di JCL.

//SAMPINST JOB 1,CLASS=6,MSGCLASS=Y,NOTIFY=&SYSUID
//*
//JSTEP1    EXEC CATLPROC,PROG=CATPRC1,DSNME=MYDATA.URMI.INPUT
//          DATAC=MYDATA.BASE.LIB1(DATA1)
//STEP1.IN1 DD DSN=MYDATA.OVER.INPUT,DISP=SHR
//*
//* The cataloged procedure is as below:
//*
//CATLPROC PROC PROG=,BASELB=MYCOBOL.BASE.LIB1
//*
//STEP1     EXEC PGM=&PROG
//STEPLIB   DD DSN=&BASELB,DISP=SHR
//IN1       DD DSN=MYDATA.URMI.INPUT,DISP=SHR
//OUT1      DD SYSOUT=*
//SYSOUT    DD SYSOUT=*
//SYSIN     DD MYDATA.BASE.LIB1(DATA1),DISP=SHR
//*
//STEP2     EXEC PGM=SORT

Dalam contoh di atas, kumpulan data IN1 menggunakan file MYDATA.URMI.INPUT di PROC, yang diganti di JCL. Oleh karena itu, file input yang digunakan dalam eksekusi adalah MYDATA.OVER.INPUT. Harap dicatat bahwa kumpulan data disebut sebagai STEP1.IN1. Jika hanya ada satu langkah di JCL / PROC, maka kumpulan data dapat dirujuk hanya dengan nama DD. Demikian pula, jika ada lebih dari satu langkah di JCL, maka kumpulan data harus diganti sebagai JSTEP1.STEP1.IN1.

//SAMPINST  JOB 1,CLASS=6,MSGCLASS=Y,NOTIFY=&SYSUID
//*
//STEP      EXEC CATLPROC,PROG=CATPRC1,DSNME=MYDATA.URMI.INPUT
//          DATAC=MYDATA.BASE.LIB1(DATA1)
//STEP1.IN1 DD DSN=MYDATA.OVER.INPUT,DISP=SHR
//          DD DUMMY
//          DD DUMMY
//*

Dalam contoh di atas, dari tiga kumpulan data yang digabungkan di IN1, yang pertama diganti di JCL dan sisanya disimpan seperti yang ada di PROC.

Mendefinisikan GDG di JCL

Generation Data Groups (GDGs) adalah kumpulan kumpulan data yang terkait satu sama lain dengan nama umum. Nama umum disebut sebagai basis GDG dan setiap kumpulan data yang terkait dengan basis disebut versi GDG.

Misalnya, MYDATA.URMI.SAMPLE.GDG adalah nama dasar GDG. Dataset tersebut diberi nama MYDATA.URMI.SAMPLE.GDG.G0001V00, MYDATA.URMI.SAMPLE.GDG.G0002V00 dan seterusnya. Versi terbaru GDG disebut sebagai MYDATA.URMI.SAMPLE.GDG (0), versi sebelumnya disebut (-1), (-2), dan seterusnya. Versi selanjutnya yang akan dibuat dalam program disebut sebagai MYDATA.URMI.SAMPLE.GDG (+1) di JCL.

Buat / Ubah GDG di JCL

Versi GDG dapat memiliki parameter DCB yang sama atau berbeda. Model awal DCB dapat ditentukan untuk digunakan oleh semua versi, tetapi dapat diganti saat membuat versi baru.

//GDGSTEP1 EXEC PGM=IDCAMS
//SYSPRINT DD  SYSOUT=*
//SYSIN    DD  *
           DEFINE GDG(NAME(MYDATA.URMI.SAMPLE.GDG)   -
           LIMIT(7)                           -
           NOEMPTY                            -
           SCRATCH)
/*
//GDGSTEP2 EXEC PGM=IEFBR14
//GDGMODLD DD  DSN=MYDATA.URMI.SAMPLE.GDG,
//         DISP=(NEW,CATLG,DELETE),
//         UNIT=SYSDA,
//         SPACE=(CYL,10,20),
//         DCB=(LRECL=50,RECFM=FB)
//

Dalam contoh di atas, utilitas IDCAMS mendefinisikan basis GDG di GDGSTEP1 dengan parameter di bawah ini yang diteruskan dalam pernyataan SYSIN DD:

  • NAME menentukan nama set data fisik dari basis GDG.

  • LIMIT menentukan jumlah maksimum versi yang dapat dimiliki basis GDG.

  • EMPTY membatalkan pencatatan semua generasi saat LIMIT tercapai.

  • NOEMPTY membuka katalog generasi terbaru.

  • SCRATCH menghapus secara fisik generasi saat tidak dikatalogkan.

  • NOSCRATCH jangan hapus set data, yaitu dapat dirujuk menggunakan parameter UNIT dan VOL.

Dalam GDGSTEP2, utilitas IEFBR14 menentukan parameter model DD yang akan digunakan oleh semua versi.

IDCAMS dapat digunakan untuk mengubah parameter definisi GDG seperti meningkatkan LIMIT, mengubah KOSONG menjadi NOEMPTY, dll., Dan versi terkaitnya menggunakan perintah SYSIN adalah ALTER MYDATA.URMI.SAMPLE.GDG LIMIT(15) EMPTY.

Hapus GDG di JCL

Dengan menggunakan utilitas IEFBR14, kita dapat menghapus satu versi GDG.

//GDGSTEP3   EXEC PGM=IEFBR14
//GDGDEL     DD  DSN=MYDATA.URMI.SAMPLE.GDG(0),
//           DISP=(OLD,DELETE,DELETE)

Pada contoh di atas, versi terbaru MYDATA.URMI.SAMPLE.GDG dihapus. Harap dicatat bahwa parameter DISP pada penyelesaian pekerjaan normal dikodekan sebagai HAPUS. Karenanya, set data dihapus saat pekerjaan menyelesaikan eksekusi.

IDCAMS dapat digunakan untuk menghapus GDG dan versi terkaitnya menggunakan perintah SYSIN DELETE(MYDATA.URMI.SAMPLE.GDG) GDG FORCE/PURGE.

  • FORCEmenghapus versi GDG dan basis GDG. Jika salah satu versi GDG disetel dengan tanggal kedaluwarsa yang belum kedaluwarsa, maka versi tersebut tidak dihapus dan karenanya basis GDG dipertahankan.

  • PURGE menghapus versi GDG dan basis GDG terlepas dari tanggal kedaluwarsa.

Menggunakan GDG di JCL

Dalam contoh berikut, versi terbaru MYDATA.URMI.SAMPLE.GDG digunakan sebagai masukan ke program dan versi baru MYDATA.URMI.SAMPLE.GDG dibuat sebagai keluaran.

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//STP01   EXEC PGM=MYCOBB
//IN1     DD DSN=MYDATA.URMI.SAMPLE.GDG(0),DISP=SHR
//OUT1    DD DSN=MYDATA.URMI.SAMPLE.GDG(+1),DISP=(,CALTG,DELETE)
//        LRECL=100,RECFM=FB

Di sini, jika GDG telah dirujuk dengan nama sebenarnya seperti MYDATA.URMI.SAMPLE.GDG.G0001V00, maka itu mengarah pada perubahan JCL setiap kali sebelum eksekusi. Menggunakan (0) dan (+1) membuatnya secara dinamis menggantikan versi GDG untuk eksekusi.