Eugene,

The first thing to do would be keep the job active and let it handle
all requests.

Regards to clearing/creating your QTEMP file, always chose the option
that generates the fewest exceptions.  So if some step is called
multiple times such that most of the time the QTEMP file exists, but
the first time it does not, then I would use the following code:

CLRPFM QTEMP/MYTEMP
MONMSG CPF3142 DO(CRTDUPOBJ xxxx)  /* File Not Found */

This way, most of the time it is just the clrpfm that is executed.

Regarding deleting all the records after the work unit and then doing
CLRPFM, that is an extra step.

I can't say for certain, but I would expect the single CLRPFM to be
faster than deleteing individual records (especially if access paths
are involved).  So I would NOT delete the records as you send them
back, and just do the CLRPFM.  This has the added benefit that by
opening in read-only mode, you allow better blocking to take place.

Regards,
Bob Crothers
Cornerstone Communications
http://www.cstoneindy.com




-----Original Message-----
From: c400-l-admin@midrange.com [mailto:c400-l-admin@midrange.com]On
Behalf Of Eugene Astanovsky
Sent: Friday, December 14, 2001 9:48 AM
To: C400-L@midrange.com
Subject: [C400-L] Optimization question

Can someone give me an advise on hour to achieve maximum perfomance in
the
following case.

I have a program, that is actually an API, called from PC via Client
Access.
This program is "seen" in WRKACTJOB under WRKSYS/QZRCSRVS. Program is
called
frequently and I have to maximize its speed.
For its operation it requires a temporary PF, which is created in QTEMP
by
the program.
What I do now in my C program is :
CRTDUPOBJ OBJ(HZY041) FROMLIB(KFILEEK) TOLIB(QTEMP) OBJTYPE(*FILE)
Program fills file with data, then sends data away, clearing this file
as
data is transferred.
When program ends it's job, file is empty, as I delete each record
after
sending it.

I looked at the job log, and each time it says :

Object HZY041 in QTEMP type *FILE already exists.

Now as performance is a bottleneck, I have several choices.
1. Leave it as is and find for a solutions somewhere else - I do not
know if
this is a performance issue :-(
2. Delete file as soon as it is empty - then I probably will not get
this
error message, but will have to create it for each call.
3. Check, if file exist before creating it and make CRTDUPOBJ only if
the
file does not exist.

My question is which of the choices is the best? And if the best is
nr.3,
then what is the most efficient way to check the existence of the file?

Any suggestions will be highly appreciated.

Regards,
Jevgeni Astanovski.


_______________________________________________
This is the C programming iSeries / AS400 (C400-L) mailing list
To post a message email: C400-L@midrange.com
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/cgi-bin/listinfo/c400-l
or email: C400-L-request@midrange.com
Before posting, please take a moment to review the archives
at http://archive.midrange.com/c400-l.



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.