On 16/09/2009, at 11:18 PM, Charles Wilt wrote:

The point would be, you'd benefit from not having to %trimr() the
fields yet don't pay a i/o hit when accessing any records.

My comment about "easier to determine the actual length" was alluding to the various trim functions no longer being necessary.

What makes you think there is no I/O hit?

It takes more work for the system to find the data in the over-flow area than in the "normal" record area--even if ALL the field data is in the overflow. Also, as additional data is added to the record in the overflow area it can become fragmented and so increase the cost to reassemble. I suspect the cost of I/O involving much data in the overflow area will outweigh any benefit obtained from these fields being automatically defined as VARYING in the program.

I'd rather define as fixed-length and then move to a VARYING field using %TRIMR. One hit in the code at a place of MY choosing and then the benefits of VARYING from then on. If I don't need to concatenate then I don't need to trim and I don't need to pay the cost either in my code or in database.


I'd consider such a field as an alternative to a small (say <50) fixed
length field. Particularly in a table access by native RPG op-codes.
Otherwise you're taking a dual i/O hit for some records even if you
don't need the variable length field. Of course, an alternative would
be to have a logical that didn't include the varying field(s).

While there are distinct advantages to using VARYING within a program it makes less sense in primarily fixed-length database system.

It will be more expensive to access varying-length fields in a database file. Whether that additional expense is prohibitive will depend on what you're doing and on what system. You may find it an acceptable cost. For me, I wouldn't bother using VARLEN on any field less than a few hundred bytes (unless I had a specific design requirement) and even then I would set the allocated length to ensure 80%-90% of the data fitted within the normal record area.


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 / \
--------------------------------------------------------------------




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.