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.