× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



It occurred to me that manually entering checks is not a normal process. Whether A/P or P/R checks, these check numbers are usually generated automatically by an application (check-writer) program.


So that made me think that, perhaps, there are other sources (check-writer?) for check numbers. If so, do these other source(s) use the same control mechanism that you have tried to describe here? As nearly everyone has pointed out, as long as the program does a CHAIN to the updateable control table (and not a CHAIN(n)), the record is locked. Period.

As has, also, been pointed out, the key structure of the control table that has been described does not match the business rules (no duplicate check numbers within a company). But I suspect that what is attempting to be described (though it isn't perfectly clear) is that there are two tables. The Company+Batch+Check# is, probably, a transaction file (why else the 'Batch'?). The check number control table is (or should be) a separate entity.

And the solution about back tracking the check number control, if the user cancels out, is hokey. If you could guarantee that one and only one user / source would ever be updating the control table, it might be possible. But you cannot and check numbers will, inevitably, be lost, voided, whatever. A review of the application and its various functions, tables, etc., is certainly merited. At the very least it might help you understand the application. Then it might provide a better perspective of the "problem" which could be conveyed here.



        * Jerry C. Adams
*IBM System i Programmer/Analyst
B&W Wholesale Distributors, Inc.* *
voice
        615.995.7024
fax
        615.995.1201
email
        jerry@xxxxxxxxxxxxxxx <mailto:jerry@xxxxxxxxxxxxxxx>



steema@xxxxxxxxxxxxx wrote:

There is only one file. A screen present a number and date-entry. First it
chains to the file, gets the number, adds 1, puts this on the screen. Then
it waits for a date. there must be a date entered. Then cmd-1, updates the
file, exits.

Hi Steve,
There is one program that generates the check number. It is a simple RPG
that chains the file by company only, adds 1 to the existing number and
places this on the screen for the user.
Are there two files (a control file holding the last check number, and
the detail file containing the details including the newly-created check
number) or are you getting the last check number from the detail file
itself?  The point being that if it is a timing issue and the program is
failing between the moment the detail file gets its record and the
control file gets it's, then you have a duplicate situation.

Can you lay out a brief outline of the timing of the events along the
lines of:

1 co   chain control
2      add   1       check
3      update control
4      exfmt
... time passes
5 key  chain  details
6      write  details

I was told that for checks, they don't
> indicate the division ever, only
company.
If the database keys are co, div, batch, check then that information is
not correct.  It may be what is _desired_ but the database does not
enforce that rule.

I still want to know what happens to
> the file lock, when a term. freezes.

What does it mean when you say 'term. freezes?'
  --buck
--
This is the RPG programming on the AS400 / iSeries (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.

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.