Unload DB2 Tables
IKJEFT01 is used to unload the DB2 table from the database and creates a flat file with the data. It uses the DSNTIAUL program to unload data from DB2 tables into sequential data sets. The table data are not affected by the unload operation. DSNTIAUL uses SQL to access DB2.
Syntax -
----+----1----+----2----+----3----+----4----+----5----+
...
//UNLOAD EXEC PGM=IKJEFT01,DYNAMNBR=50
//STEPLIB DD DSN=XXXXXX.SDSNEXIT,DISP=SHR
// DD DSN=XXXXXX.SDSNLOAD,DISP=SHR
//**************DB2 query to unload the data
//SYSIN DD *
db2_query WITH UR;
/*
//SYSTSIN DD *
DSN SYSTEM(DB2T) >> DB2 System
RUN PROGRAM(DSNTIAUL) - >> unloading program
PLAN(DSNTIAUL) - >> Plan authorized for DB2T
LIB('XXXXXX.RUNLIB.LOAD') - >> Program existed library
PARMS('SQL') >> Program Parm
END
//****************Unloading file
//SYSREC00 DD DSN=ps-file-to-unload-table-data,...
//****************Unloading table structure
//SYSPUNCH DD DSN=ps-file-to-store-table-structure,...
//*
...
Practical Example -
Scenario - JCL to unload the db2 table (EMPLOYEE) using IKJEFT01 utility.
JCL -
----+----1----+----2----+----3----+----4----+----5----+
...
//UNLOAD EXEC PGM=IKJEFT01,DYNAMNBR=50
//STEPLIB DD DSN=DSNA10.DBAG.SDSNEXIT,DISP=SHR
// DD DSN=DSNA10.SDSNLOAD,DISP=SHR
//SYSIN DD *
SELECT * FROM EMPLOYEE WITH UR;
/*
//SYSTSIN DD *
DSN SYSTEM(DBAG)
RUN PROGRAM(DSNTIAUL) -
PLAN(DSNTIB10) -
LIB('DSNA10.DBAG.RUNLIB.LOAD') -
PARMS('SQL')
END
/*
//SYSREC00 DD DSN=MATEPK.EMPL.UNLOAD,
// DISP=(NEW,CATLG,DELETE),
// UNIT=SYSDA,SPACE=(CYL,(1,1),RLSE)
//SYSPUNCH DD DSN=MATEPK.EMPL.SYSPUNCH,
// DISP=(NEW,CATLG,DELETE),
// UNIT=SYSDA,SPACE=(CYL,(1,1),RLSE)
...
Note!
Change the STEPLIB libraries, SYSIN query, SYSTEM, PLAN, LIB, SYSREC00 and SYSPUNCH according to your system setup, and do not change the PROGRAM name.
Once the details are updated, the above JCL can directly submit to run the program.