There is lots of documentation and discussion regarding how the scope of static buffers, relative to transaction scope, affects lock management. I have not been able to find any documentation or discussion of how this works with dynamic buffers. Based on experimentation I've found that downgrading of locks works exactly the same; when a transaction ends the lock downgrades from EXCLUSIVE to SHARE. However, from what I can tell, as long as there is a record in the buffer it will behave like a free reference and that SHARE-LOCK will be retained. Is there any way to strongly scope a dynamic buffer to a block? Or some other method of releasing, rather than downgrading, that EXCLUSIVE-LOCK?
I'm just looking for best practices or suggestions, or a pointer to documentation on the subject if someone knows where it can be found.
Thanks,
Chris
bufferHandle:buffer-release() will release the record, and the record's lock will go to no-lock at the end of the TX.
bufferHandle:find-current(no-lock) will mark the record's lock to be released at the end of the TX.
or you could delete the object which will mark the record's lock to be released at the end of the TX.
You can also put the delete object in a finally block at the end of the routine - like so:
FINALLY:
delete object bufferObject.
END FINALLY.
Thanks for the quick replies and suggestions!
You both suggest using BUFFER-RELEASE() and I've read quite a few threads that include discussions of "RELEASE buffer" being a red flag. Are there any similar concerns with using BUFFER-RELEASE()? Maybe it's just that the two are completely different in the sense that "RELEASE buffer" is a strong sign that the record scope is unnecessarily large and the same controls don't exist for dynamic buffers?
Any thoughts on that?
The issue with RELEASE is the mistaken belief that this statement clears the lock, even when you're in the middle of a TX. That's not the case - a locked record in a TX will remain locked until the TX ends regardless of whether the record's in scope or not.
In this context, BUFFER-RELEASE() will kick the record out of scope, and it'll go to NO-LOCK after the TX ends. (And not before. :))
Regarding " BUFFER-RELEASE() will kick the record out of scope, and it'll go to NO-LOCK after the TX ends".
The record is out of scope and it will not be in the buffer anymore, so it does not go to NO-LOCK. It just is not in scope anymore at all, as long as there is no other buffer with that same record in scope. What will happen at the end of the transaction is that the lock will be released instead of being downgraded.
Fernando - I do believe you're agreeing with me....