MVSFORUMS.com Forum Index MVSFORUMS.com
A Community of and for MVS Professionals
 
 FAQFAQ   SearchSearch   Quick Manuals   RegisterRegister 
 ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

Dynamically allocating/freeing DL/1 DB

 
Post new topic   Reply to topic   printer-friendly view    MVSFORUMS.com Forum Index -> IMS
View previous topic :: View next topic  
Author Message
misi01
Advanced


Joined: 02 Dec 2002
Posts: 618
Topics: 172
Location: Stockholm, Sweden

PostPosted: Mon Oct 22, 2018 5:36 am    Post subject: Dynamically allocating/freeing DL/1 DB Reply with quote

Not sure if this can even be done, but I'll explain the background first.

Due to GDPR requirements here in Europe, we have to log any access to production databases (eg, when copying a specific insurance policy from prod to a private database).
Private databases always have the same naming standard, 'userid.DIALDBDT.DBNAME' (where DBNAME is the database name). Every time the user/developer copies from prod, we log this in a DB2 table.

Every so often (14 days or so), the idea is to loop through this table and delete copied prod data from the private databases (WITHOUT deleting other segments). For example, as usera, I might copy prod ID's 10 and 20, and userb might copy ID's 20 and 30.

The program so far reads the DB2 table, allocates the 'userid.DIALDBDT.DBNAME' databases and calls an existing program (progB) that then deletes all ID's created in a file (for userA 10 & 20, for userb, 20 & 30).

The program works fine first time round for usera inasmuch as usera's databases are allocated as SHR, progB is called that reads the databases and processes them.

My problem is that I can never loop round and process userb. I try freeing usera's databases (after the call to progb) via a simple free dd(DBNAME) but I get bpxwdyn return code 69206016 (hex 0420 0000) which according to the manual is
Quote:

0420 Meaning: Specified ddname or dsname associated with an open data set. (ddname allocation, concatenation, deconcatenation, unallocation, dsname allocation)


My question is, is there any way of "closing/releasing" the existing DL/1 databases (yes, I realize that "closing" a DL/1 database is a bit of an oxymoron).
_________________
Michael
Back to top
View user's profile Send private message Send e-mail
kolusu
Site Admin
Site Admin


Joined: 26 Nov 2002
Posts: 12367
Topics: 75
Location: San Jose

PostPosted: Mon Oct 22, 2018 8:13 am    Post subject: Reply with quote

misi01,

Why not schedule a batch job that every runs every other week ( twice/thrice in a month) which unloads the private database and then run thru a utility to drop off all the unwanted records and then reload it back?
_________________
Kolusu - DFSORT Development Team (IBM)
DFSORT is on the Web at:
www.ibm.com/storage/dfsort

www.linkedin.com/in/kolusu
Back to top
View user's profile Send private message Send e-mail Visit poster's website
misi01
Advanced


Joined: 02 Dec 2002
Posts: 618
Topics: 172
Location: Stockholm, Sweden

PostPosted: Mon Oct 22, 2018 9:13 am    Post subject: Reply with quote

That could work but would be rather kludgy (IMHO).

One of the main arguments against it would be the fact that there already exists a program that deletes the segments in the databases.

I supose one way to do it would be to have the various databases allocated with a variable as the HLQ, something like
Code:

//DAA01  DD DISP=SHR,DSN=&HLQ..DIALDBDT.DAA01

and then run the JCL with user1, user2, user3 etc etc as &HLQ. That way, the loop would be based on the JCL rather than within the cobol program.

(I suppose one way to do it would be to use Rexx to access the DB2 table, extract the unique userids that need to be cleaned up, and then simply create the JCL via skeletons and submit each one. That way, you're using the existing program without doing more work than necessary, as well as never having to change anything if a new userid comes along.)

I'll look into that variation.
_________________
Michael
Back to top
View user's profile Send private message Send e-mail
misi01
Advanced


Joined: 02 Dec 2002
Posts: 618
Topics: 172
Location: Stockholm, Sweden

PostPosted: Wed Oct 24, 2018 5:44 am    Post subject: Reply with quote

Thought I'd update our resulting solution.

We went with a Rexx script that reads the DB2 table sorted on userid. For each unique userid, the script creates a file containing the arguments needed for the program to run, allocates a skeleton, creates the JCL and then submits the job that reads the file and processes it..

That way, we have one job per unique userid selected from the DB2 table.

Much, much simpler.
_________________
Michael
Back to top
View user's profile Send private message Send e-mail
Display posts from previous:   
Post new topic   Reply to topic   printer-friendly view    MVSFORUMS.com Forum Index -> IMS All times are GMT - 5 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


MVSFORUMS
Powered by phpBB © 2001, 2005 phpBB Group