I guess that is relative... I might give this option another look. With this option I need to make changes to different location of code for each READE. I'll have to add the RECNO keyword on the logic, add a new physical file F spec, add a chain statement after the READE and change the update statement to use the Physical's record format name. If field name in the logic happen to be renamed, it would present another challenge. As mentioned, it involve several READE statements in several diff programs. A unify way to tackle this would be best.
With the READP then READE option, I can simply change the READE to EXSR READE_fileName and handle all this READP and READE in one isolated sub-routine.


"Paul Therrien" wrote in message news:mailman.642.1330716342.14575.rpg400-l@xxxxxxxxxxxx...

If fetching the physical file record with rrn is ugly, how much uglier
is it to insert readp logic in the middle of a reade loop?
Using a read-only logical file as your main driver removes your record
locking issues and removes any record locking logic you have already
probably had to insert in the program.
Chaining out to the PF with the RRN and then issuing an update to the PF
where you are now issuing an update to the logical file are the only
logic changes required.
I am sure I am oversimplifying your programs and they are probably
monstrous, but adding logic to do reade(n) and then readp and reade
without the (n) in order to update the record seems to add more
monstrous (and inelegant), code on top of what already exists.


Paul Therrien
Orion South, Inc.
504-374-9551
800-437-7173
ptherrien@xxxxxxxxxxxxxxx

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Hockchai Lim
Sent: Friday, March 02, 2012 11:49 AM
To: rpg400-l@xxxxxxxxxxxx
Subject: Re: Re-READ the current record

There is always a possibility. But the chance of it happen is very low
since each thread processes a different customer. My other option is to
put a Physical file that is key by RRN and chain back to it by RRN and
perform update on it. But this method also has it's own ugly problem.
If it is a brand new program, it wouldn't be so bad. But it is an
existing process and it is quite a massive process to deal with. If you
have dealt with Billing or Invoicing process before, you probably knows
that this type of process is not of those that you want to make a
mistake on.





"Brian Johnson" wrote in message
news:mailman.598.1330709340.14575.rpg400-l@xxxxxxxxxxxx...

Is it guaranteed that READP followed by READ will get you back to your
original record in all cases? I'm thinking of concurrent updates or
inserts that that place a different record after the record read by
READP. You have concurrent updates; are other billing threads
performing inserts? What about other non-billing processes that may be
updating the table in question?


--
Brian Johnson
brian.johnson.mn@xxxxxxxxx

--
This is the RPG programming on the IBM i / System i (RPG400-L) mailing
list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives at
http://archive.midrange.com/rpg400-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.