作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对最后一条消息感到抱歉。我在我的问题上做了一个粘贴。长问题简短,当在 try/catch 块内使用 sp_GetAppLock 时,我应该在捕获异常时调用 sp_ReleaseAppLock 吗?
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
BEGIN TRAN
DECLARE @res INT
EXEC @res = sp_getapplock
@Resource = 'This a Lock ID 3',
@LockMode = 'Exclusive',
@LockOwner = 'Transaction',
@LockTimeout = 60000,
@DbPrincipal = 'public'
if @res < 0
begin
declare @errorMessage nvarchar(200)
set @errorMessage =
case @res
when -1 then 'Applock request timed out.'
when -2 then 'Applock request canceled.'
when -3 then 'Applock involved in deadlock'
else 'Parameter validation or other call error.'endraiserror (@errorMessage,16,1)
end
SELECT...
INSERT...
UPDATE...
COMMIT TRANSACTION -- THIS RELEASES THE APPLOCK
RETURN 0; END TRY
BEGIN CATCH
-- ROLLBACK TRANSACTION IF NEEDED IF @@TRANCOUNT > 0 ROLLBACK
/* Exception handling stuff here. Should I call sp_releaseapplock? ... ... */
-- return the success code RETURN -1;
END CATCH
最佳答案
Locks associated with the current transaction are released when the transaction commits or rolls back.
关于SQL 2005 sp_GetAppLock --- 何时调用 sp_ReleaseAppLock?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1380707/
对最后一条消息感到抱歉。我在我的问题上做了一个粘贴。长问题简短,当在 try/catch 块内使用 sp_GetAppLock 时,我应该在捕获异常时调用 sp_ReleaseAppLock 吗? S
我使用的是 SQL Server 的锁定函数,如下所示 sp_getapplock sp_releaseapplock 我已指定@LockOwner = 'Session' 但是每次都会抛出以下异常:
我是一名优秀的程序员,十分优秀!