|
<<SNIP>>
_METHOD A -- checksums or hash code_
1. when you first read the record, (with no lock), compute a
checksum or "hash" of the contents of the entire record buffer.
2. present the data on-screen for the user to (possibly) update.
3. when the user has updated some fields, re-read the original
database record again, with record lock this time, into another
buffer and re-compute the check-sum or hash code. If the hash
or checksum is still the same then no one else has updated the
record in the meantime, so it is now "safe" to update that
record with the changes made by the user. (The update will
release the record lock automatically.)
4. if the check-sum or hash does not "match" you need to release
the record lock and inform the user that another person has
updated the same record -- present the (newly updated) data
again, and ask the user to re-enter the changes.
(... lather, rinse, repeat ... as needed until the update
is successful or the user presses F12=Cancel ...)
_METHOD B -- a similar but simpler approach_
A simpler, low-cost variation on the above, relies on adding a
single "UPDATEID" field to each file you want to update "lock-free"
-- it can be a binary integer or a packed numeric field, if binary,
you can use a 2-byte or 4-byte integer, or packed with at least 5
or more digits. Proceed as follows:
* whenever a record is first added to the file, initialize this
UPDATEID field to zero. (Could be handled by an INSERT trigger)
* whenever any application program updates any record in this file,
you must ensure that the UPDATEID value is always incremented by 1
The algorithm for updating is similar to the above, with these
changes. Instead of computing a checksum, you just remember
the UPDATEID value ... and compare it, as follows:
1. when you first read the record, (with no lock), save the UPDATEID
value for use later.
2. present the data on-screen for the user to possibly update.
3. when the user has updated some fields, re-read the original
record again, with a record lock this time, into another
buffer and If the UPDATEID is still the same as the saved
value, then no one else has updated the record in the
meantime, so it is now "safe" to update that record with the
changes made by the user. Increment the value of UPDATEID in
the record buffer about to be updated (This update I/O will
also release the record lock automatically.) (An UPDATE
trigger could handle incrementing the UPDATEID field.)
4. if the UPDATEID does not "match" you need to release the
record lock and inform the user, that the record has been
updated by someone else, and present the (newly updated) data
again, and ask the user to re-enter any changes. (... lather,
rinse, repeat ... as needed until the update is successful or
the user presses F12=Cancel ...)
The main "down side" to METHOD B is that _everyone must follow_ these
rules_ to ensure that the UPDATEID is always incremented whenever a
record is updated. (The "increment" logic could be put in a trigger
to make that part easier.) But, you must still add logic in your
applications to save the UPDATEID on the first READ and compare it
again, just prior to any update ... -- if anyone forgets or ignores
these rules, your users will suffer "lost changes" like what happens
if you use no record locking at all.
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.