|
I find the best way to remember this is to visualize the records in keyed order and then consider SETLL as equivalent to "position just before key value" and SETGT as "position just after key value". So for example, if I have key values A, B, and C, if they are in ascending order then B comes after A and before C; if they are in descending order, then B comes after C and before A. It may be helpful to set up a test file & run some simple tests. I think you'll find: If the key value exists in the file: Ascending keys: SETLL and READ will retrieve the record with that key value SETGT and READ will retrieve the next record (unless it's the highest key value in the file, in which case READ with no error will retrieve that key) Descending keys: SETLL and READ will retrieve the record with that key value SETGT and READ will retrieve the next record (unless it's the lowest key value in the file, in which case READ with no error will retrieve that key) If the key value does not exist in the file: Ascending keys: SETLL and READ will retrieve the record with the next highest key value (nb: if it's higher than the highest key, no record is read) SETGT and READ will retrieve the record with the next highest key value (nb: if it's higher than the highest key, no record is read) Descending keys: SETLL and READ will retrieve the record with the next lowest key value (nb: if it's lower than the lowest key, no record is read) SETGT and READ will retrieve the record with the next lowest key value (nb: if it's lower than the lowest key, no record is read) Admittedly, this can be a little confusing, but I think the usefulness of these actions makes the effort worthwhile. . . . rpg400-l@midrange.com writes: ><snip> >I want to access a file by descending key & would you believe I have never >done that before via READ* variants? >I have got a logical of the records in descending sequence & I am not sure >if >my logic would be same pattern >ie. *LOVAL SETLL file then READ loop ("forwards" through the records) >or if I should *HIVAL SETHH at begeinning because I'm going to be reading >backwards. > >Reason for this is I want to flag the oldest entries for deletion & I >thought >I would start at the beginning of the point I want to keep. ><end snip> Mike Naughton Senior Programmer/Analyst Judd Wire, Inc. 124 Turnpike Road Turners Falls, MA 01376 413-863-4357 x444 mnaughton@juddwire.com
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.