Mike Cunningham wrote:
I need to get data from a file but I know that for every 100 records
I process only 1 will have a record in the file I am going to CHAIN
to. Is it faster to first to a SETLL to see if the key exists and if
it does do a CHAIN or is just doing the CHAIN just as fast? Many
years ago in the S/38 days I know the recommendation was to the SETLL
then the CHAIN.
With RPG/400 (and S/38 RPG III), a CHAIN that doesn't find a record
involves an exception. A SETLL that doesn't find an exact record only
involves an exception if the search argument is greater than all the
records in the file. So with RPG/400, SETLL was indeed better than
CHAIN if most of the records were not going to be found.
With ILE RPG, both CHAIN and SETLL use return codes instead of
exceptions to communicate "not found"; setting and checking a return
code is much much faster than creating and handling an exception. The
relative performance of CHAIN and SETLL isn't at all the same as it is
for RPG/400.
If the performance difference would really matter, you should do some
performance comparisons on your actual file. Set up some hard-coded
representative search values, and do your 99% failure + 1% success
searches in a loop, CHAIN in one program and SETLL+READ in another.
Make the loops run long enough that the entire program takes at least a
minute to run, and see if one or the other is noticeably faster. It
might be the case that the position of the key within the set of keys
makes a difference, so for both the not-found and found cases, you might
need to have many different search values to have a representative test.
As an Amazon Associate we earn from qualifying purchases.
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.