Joe,

Your first example, getting the GL number account number from the item
class.
SELECT iim.IPROD, iim.IDESC, iim.ICLAS, iic.ICGL
FROM iim
join iic on iim.iclas=iic.iclas
And if this is something users are doing all over the place in query's and
whatnot then a view that does this should be created so they don't have to
figure out this join themselves all the time.
Now, whether or not it physically chains out to IIC on each row then, or if
it reads it from cache, sounds more like a debate for your new website.

Your second example on checking the item number.
Technically you could write the order record out and check the status of
the write.  It it was a constraint error you could check the constraint
message and then find out that the error was due to the item number being
invalid.  This may sound clunky to you, but in general people should be
putting this kind of error trapping in their code anyway.  Because, sooner
or later, someone will add constraints and/or triggers to your file and
should handle the error(s) reported back.  A rare instance might be you
chain out and it's a valid item number.  User keys in the rest.  You write
out the order detail record but, in the meanwhile, someone deleted the item
number.
The problem with most current error trapping is too much of it is
assumption.  'If my write fails it must be due to a duplicate key', that
kind of garbage.

Rob Berendt
--
Group Dekko Services, LLC
Dept 01.073
PO Box 2000
Dock 108
6928N 400E
Kendallville, IN 46755
http://www.dekko.com


|-----------------------------+-------------------------------------------|
|   "Joe Pluta"               |                                           |
|   <joepluta@xxxxxxxxxxxxxxxx|                                           |
|   m>                        |                                         To|
|   Sent by:                  |                                    "'Midra|
|   midrange-l-bounces@midrang|                                    nge    |
|   e.com                     |                                    Systems|
|                             |                                    Technic|
|   07/26/2004 09:45 AM       |                                    al     |
|                             |                                    Discuss|
|         Please respond to   |                                    ion'"  |
|         Midrange Systems    |                                    <midran|
|       Technical Discussion  |                                    ge-l@mi|
|      <midrange-l@xxxxxxxxxxx|                                    drange.|
|                m>           |                                    com>   |
|                             |                                         cc|
|                             |                                           |
|                             |                                    Subject|
|                             |                                    RE:    |
|                             |                                    Single |
|                             |                                    record |
|                             |                                    access |
|                             |                                    really |
|                             |                                    require|
|                             |                                    d (was |
|                             |                                    RE:    |
|                             |                                    Views  |
|                             |                                    and    |
|                             |                                    Indexes|
|                             |                                    )      |
|                             |                                           |
|                             |                                           |
|                             |                                           |
|                             |                                           |
|                             |                                           |
|                             |                                           |
|-----------------------------+-------------------------------------------|






> From: CWilt@xxxxxxxxxxxx
>
> Option B is where the solution lies.
>
> How about providing some examples of standard business operations
where
> you
> feel single record access is required and we'll see if there isn't a
way
> to
> remove the requirement.

You're kidding me, right? Uh, off the top of my head - getting the GL
account number from the item class.   Requires chaining to the item
class file with the item class from the item master.

And in any business application, there are hundreds and hundreds of
instances like this.  In fact, that's the idea behind a configurable ERP
system: you read the database to determine your logic.


> Most often used one in RPG I can think of is checking a record's
existence
> to ensure data integrity.
> The need for this is eliminated with a properly defined DB that uses
> constraints properly.

This is hardly ever used.  We chain to see if the customer entered a
valid item number, and that's not going to be handled by referential
integrity.


> Another place would be a "work-with" type application where a user is
> presented with a set of items from which they chose one to edit or
> display.
> Off the top of my head, one could possibly use the same cursor that
> presents
> the set to present the single item.  This would eliminate the
performance
> differences that you've seen in your testing.  Perhaps somebody else
has a
> better idea.

How could you use the same cursor?  By doing somehow calculating the row
number and doing a FETCH -N?  It's been stated (though not proven
quantitatively) that relative fetches include I/O overhead of their own.

And that's not really the point.  The point is that you have no real
answer to this, you're just winging it.  And that's really not
acceptable in a technical discussion.

At least not to me.  I will no longer dispute "maybes" and "mights".  If
you have a solution, then write it, test it, and let us know the
results.  As of today, the day of "possible" solutions used as arguments
is over, at least for me.  From now on, the only valid solution is one
that has been tested.  And those will be posted at the IAAI website.

Joe

--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list
To post a message email: MIDRANGE-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/midrange-l.




As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
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.