The one thing that has not been mentioned with respect to the different
type of subfiles is that a load-all subfile retains the data since the
initial load all.
If the user is in that data for any decent amount of time, then the
original data could have changed and no matter how many times that you
page-up and/or page-down (or position to) the data is STILL old
A page at a time sub file should always give you the latest data each time
you page-up, page-down or position to
Each type of subfile has their pro's and con's
Which one to choose depends upon what the business need is as well as how
much work the programmer wants/needs to put into the task
Alan Shore
Programmer/Analyst, Direct Response
E:AShore@xxxxxxxx
P:(631) 200-5019
C:(631) 880-8640
"If you're going through Hell, keep going" - Winston Churchill
Jerry Adams
<Jerry@bwwholesal
e.com> To
Sent by: RPG programming on the IBM i /
rpg400-l-bounces@ System i <rpg400-l@xxxxxxxxxxxx>
midrange.com cc
Subject
02/18/2010 12:19 Load-All Subfile Performance (Was:
PM "Constant" performance question)
Please respond to
RPG programming
on the IBM i /
System i
<rpg400-l@midrang
e.com>
My experience, since the Power4 chip, has been that a load-all subfile
(which is limited to 9,999 records) even when multiple tables are involved
is not perceivable by a user.
For example, I allow users to display a list of items based upon anything,
anywhere in the description. There are > 4,000 records in the Item Master;
I use SCAN to determine if the record is wanted, plus allow them to ignore
(logically) deleted records, then display a list that meets their
requirements. Every single record in the Item Master, of course, has to be
read and the subfile record built from it as well as a field from a second
table. Just ran it against a production system with >20 user jobs running;
the response is sub-second. I have several others subfile programs where
the result could be "a lot". I do agree that the time consuming element in
any subfile is accessing the tables to provide the subfile, not the actual
subfile processing.
Perhaps it is just me, but I find coding and processing load-all's a tad
easier than page-at-a-time's. Rick pointed out that his original question
involved a standards document. In a one-man System i shop, I have the
luxury of setting (and changing) programming standards. One of the
standards that has changed is, obviously, page-at-a-time to load-all.
Standards, though, cannot be carved in granite. Another example: The
program I mentioned (above) uses RLA to built the subfile, but more often
these days I use SQL to access the table(s) and do a lot of the grunt work
for me (I'm still pretty lame at SQL compared to the stuff I see others
doing in the Midrange-L forum). Ergo, the standard changed.
Jerry C. Adams
IBM System i Programmer/Analyst
--
B&W Wholesale
office: 615-995-7024
email: jerry@xxxxxxxxxxxxxxx
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
On Behalf Of McGovern, Sean
Sent: Thursday, February 18, 2010 9:58 AM
To: RPG programming on the IBM i / System i
Subject: RE: "Constant" performance question
That's OK if you are loading a subfile from one (master) file. My
experience is that more often than not, there is also business logic
required to determine whether a record should be written to subfile.
This can lead to a big performance overhead using a load-all subfile.
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Jerry Adams
Sent: 18 February 2010 15:02
To: RPG programming on the IBM i / System i
Subject: RE: "Constant" performance question
Plus isn't it more important that the code be productive from both a
programmer- and user-point-of-view? Unless I find (or have reported to
me) significant issues with performance, I try (not always successfully
it turns out) to write code that (a) the next programmer can most easily
decipher (even though this is a one-man System i-wise shop), and (b)
gives the user/client that easiest path to their objective. Those that
dwell upon nano- or micro-second issues have more important issues that
they need to address.
As an example, the other discussion about subfile performance seems a
little ridiculous to me. On the original AS/400 models there is a
significant difference between page-at-a-time and load-all subfiles. At
least since the Power4 chip the difference is negligible; loading a
1000+ load-all subfile (never had to go the full limit), is still
sub-second response. And, in my opinion, writing a load-all is a heck
of a lot easier to write and understand than a page-at-a-time. Since
it's not a programmer issue, if it ever becomes an issue with the
user/client, I would have to revisit that premise, but a couple of micro
seconds is not something I am going to address.
Jerry C. Adams
IBM System i Programmer/Analyst
--
B&W Wholesale
office: 615-995-7024
email: jerry@xxxxxxxxxxxxxxx
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Simon Coulter
Sent: Wednesday, February 17, 2010 2:40 PM
To: RPG programming on the IBM i / System i
Subject: Re: "Constant" performance question
On 18/02/2010, at 6:52 AM, Paul Jackson wrote:
if you had to compare a value to
see if it was 0602 multiple times I would expect the named constant to
be more efficient because the system does not have to check each time
for content change unlike with the data structure subfield.
What makes you think the compiler generates code to check if the
content has changed? Surely it would be simpler to just compare
against the current value (changed or otherwise)?
As far as I know there is no difference in efficiency at run-time--and
if there were it would likely be so small as to be truly insignificant
even over multiple iterations.
Regards,
Simon Coulter.
--------------------------------------------------------------------
FlyByNight Software OS/400, i5/OS Technical Specialists
http://www.flybynight.com.au/
Phone: +61 2 6657 8251 Mobile: +61 0411 091 400 /"\
Fax: +61 2 6657 8251 \ /
X
ASCII Ribbon campaign against HTML E-Mail / \
--------------------------------------------------------------------
--
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.
--
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.
--
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.
--
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.