Interesting.  I'll stick to using READE.  I'm willing to expend a few more 
processing minutes to be sure I've got correct logic.

Ron Power
Programmer
Information Services
City Of St. John's, NL
P.O. Box 908
St. John's, NL
A1C 5M2
709-576-8132
rpower@xxxxxxxxxx
http://www.stjohns.ca/
___________________________________________________________________________
Success is going from failure to failure without a loss of enthusiasm. - 
Sir Winston Churchill




"Wilt, Charles" <CWilt@xxxxxxxxxxxx> 
Sent by: rpg400-l-bounces@xxxxxxxxxxxx
2005/11/23 09:45 AM
Please respond to
RPG programming on the AS400 / iSeries <rpg400-l@xxxxxxxxxxxx>


To
"RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx>
cc

Subject
RE: Optimizing File I-O in RPG IV/ I-Series






Note that while the use of READE does prevent blocking and as I understand 
it generally performs worse that READ + your own test.

The benefit to READE is that does key comparisons correctly when using 
special key features such as ALTSEQ, ABSVAL, ALWNULL.

See this message from Barbara Morris:
http://archive.midrange.com/rpg400-l/200503/msg00899.html


HTH,

Charles Wilt
--
iSeries Systems Administrator / Developer
Mitsubishi Electric Automotive America
ph: 513-573-4343
fax: 513-398-1121
 

> -----Original Message-----
> From: rpg400-l-bounces@xxxxxxxxxxxx 
> [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Fleming, Greg (ED)
> Sent: Wednesday, November 23, 2005 8:05 AM
> To: RPG programming on the AS400 / iSeries
> Subject: RE: Optimizing File I-O in RPG IV/ I-Series
> 
> I'm sure the gurus can explain it better than I, but READE 
> actually performs a bit counter-intuitively.
> 
> It actually resets the pointer every time it is invoked.  So 
> you setLL the first time, then when you READE it looks at 
> your key and reads through all the records again to get to 
> the next one, and so on.  At least that's the way it's been 
> explained to me.  We made it a standard in our shop to never 
> use READE, and when we did, the performance of our programs 
> improved dramatically.
> 
> Instead, we use:
> 
> Key SetLL File
> DoW 1 = 1
> Read File
> If %Eof or Key <> Record
>    Leave
> EndIf
> Process Record
> EndDo
> 
> 
> Greg
> 
> >-----Original Message-----
> >From: rpg400-l-bounces@xxxxxxxxxxxx 
> [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
> >On Behalf Of RPower@xxxxxxxxxx
> >Sent: Wednesday, November 23, 2005 7:58 AM
> >To: RPG programming on the AS400 / iSeries
> >Subject: RE: Optimizing File I-O in RPG IV/ I-Series
> >
> >Huh?  I reade will progressively read thru record after 
> record until it
> >finds a non-matching record to the key.  Why would you want 
> to skip the
> >reade and then do an if comparision when reade does it all 
> in one step?  A
> >chain finds the very first record, a reade finds the next 
> matching record.
> > So they aren't the same.
> >
> >Ron Power
> >Programmer
> >Information Services
> >City Of St. John's, NL
> >P.O. Box 908
> >St. John's, NL
> >A1C 5M2
> >709-576-8132
> >rpower@xxxxxxxxxx
> >http://www.stjohns.ca/
> >_____________________________________________________________
> ______________
> >Success is going from failure to failure without a loss of 
> enthusiasm. -
> >Sir Winston Churchill
> >
> >
> >
> >
> >"Fleming, Greg \(ED\)" <GFLEMING@xxxxxxxxxxxxxxxxxxxx>
> >Sent by: rpg400-l-bounces@xxxxxxxxxxxx
> >2005/11/23 09:23 AM
> >Please respond to
> >RPG programming on the AS400 / iSeries <rpg400-l@xxxxxxxxxxxx>
> >
> >
> >To
> >"RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx>
> >cc
> >
> >Subject
> >RE: Optimizing File I-O in RPG IV/ I-Series
> >
> >
> >
> >
> >
> >
> >Don't do a READE.
> >
> >Do a READ and then leave when you get to a record you don't want.
> >Doing a READE is like Chaining over and over again.
> >
> >Greg
> >
> >>-----Original Message-----
> >>From: rpg400-l-bounces@xxxxxxxxxxxx
> >[mailto:rpg400-l-bounces@xxxxxxxxxxxx]
> >>On Behalf Of Weber, Richard
> >>Sent: Wednesday, November 23, 2005 7:49 AM
> >>To: 'RPG programming on the AS400 / iSeries'
> >>Subject: RE: Optimizing File I-O in RPG IV/ I-Series
> >>
> >>Maybe you're already doing this: Skip the update statement 
> for records
> >>whose
> >>data hasn't actually been changed.
> >>
> >>Rick Weber  |  TOYS 'Я' US International
> >>
> >>-----Original Message-----
> >>From: Jim Wiant [mailto:Jim.Wiant@xxxxxxxxxxxxxxxx]
> >>Sent: Tuesday, November 22, 2005 7:18 PM
> >>To: rpg400-l@xxxxxxxxxxxx
> >>Subject: Optimizing File I-O in RPG IV/ I-Series
> >>
> >>We have a series of programs that update files for assorted 
> maintenance.
> >>The time these programs are taking is becoming excessive.
> >>
> >>In most cases, the RPG code is very simple.
> >>
> >>Key             SETLL                                           file
> >>Key             READE                                           file
> >>                (Do until EOF)
> >>                UPDATE                          record
> >>Key             READE                                           file
> >>                END DO
> >>
> >>I don't see how the code can get might tighter. Is there 
> any reasonable
> >>compiling options/ CL overrides, etc. that could improve 
> such a routine
> >>when it
> >>needs to process a large number of records? We're not opposed to
> >>changing code, but if just a few H spec changes and/or 
> compiling options
> >>could gain
> >>us a bit of performance, it would help us out.
> >>
> >>I've tried a few of the basics (OPTIMIZE(*FULL), NoDEBUGIO, 
> etc.) but
> >>didn't see much of a change in my benchmarks.
> >>
> >>Thanks for any help
> >>
> >>Jim Wiant
> >>
> >>
> >>Once a job is fouled up, anything done to improve it makes it worse.
> >>Finagle
> >>
> >>
> >>This message has been sent from Foodstuffs (Auckland) Limited
> >>("Foodstuffs").
> >>
> >>The information contained in this message and or attachments
> >>is intended only for the person or entity to which it is
> >>addressed and may contain confidential and/or privileged
> >>material. Any review, retransmission, dissemination or other
> >>use of, or taking of any action in reliance upon, this
> >>information by persons or entities other than the intended
> >>recipient is prohibited. If you received this in error,
> >>please contact the sender and delete the material from any
> >>system and destroy any copies.
> >>
> >>The views and opinions expressed in this message may be those
> >>of the individual and not necessarily those of Foodstuffs,
> >>and are not given or endorsed by it.
> >>
> >>Please note that this communication does not designate an
> >>information system for the purposes of the Electronic
> >>Transactions Act 2002.
> >>--
> >>This is the RPG programming on the AS400 / iSeries 
> (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.
> >>
> >>============================================================
> ============
> >>This email message is for the sole use of the intended 
> recipient (s) and
> >>may
> >>contain confidential and privileged information. Any 
> unauthorized review,
> >>use, disclosure or distribution is prohibited. If you are not the
> >intended
> >>recipient, please contact the sender by reply email and destroy all
> >copies
> >>of the original message. To reply to our email 
> administrator directly,
> >send
> >>an email to EmailAdmin@xxxxxxxxxxxx
> >>Toys "R" Us, Inc.
> >>
> >>--
> >>This is the RPG programming on the AS400 / iSeries 
> (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.
> >
> >
> >--
> >This is the RPG programming on the AS400 / iSeries 
> (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.
> >
> >
> 
> 
> -- 
> This is the RPG programming on the AS400 / iSeries (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.