SQL Server ROWLOCK over SELECT如果不存在INSERT事务
我已经从SQL Server 2005升级到2008.我记得在2005年,ROWLOCK根本无法工作,我不得不使用PAGELOCK或XLOCK来实现任何类型的实际锁定。我知道读者会问“你做错了什么?”没有。我最终证明我可以编辑一个“ROWLOCKED”行,但如果我升级锁定级别则不行。我没有机会看到它是否适用于SQL 2008.我的第一个问题是有没有人在2008年遇到过这个问题?
我的第二个问题如下。我想测试一个值是否存在,如果存在,则执行相关列的更新,而不是整行的插入。这意味着如果找到该行,则需要将其锁定,因为维护过程可能会在进程中删除此行,从而导致错误。
为了说明原理,以下代码是否有效?
BEGIN TRAN
SELECT ProfileID
FROM dbo.UseSessions
WITH (ROWLOCK)
WHERE (ProfileID = @ProfileID)
OPTION (OPTIMIZE FOR (@ProfileID UNKNOWN))
if @@ROWCOUNT = 0 begin
INSERT INTO dbo.UserSessions (ProfileID, SessionID)
VALUES (@ProfileID, @SessionID)
end else begin
UPDATE dbo.UserSessions
SET SessionID = @SessionID, Created = GETDATE()
WHERE (ProfileID = @ProfileID)
end
COMMIT TRAN
没有找到相关结果
已邀请:
1 个回复
搁手
) 隔离级别=锁定持续时间,并发性(
) 模式=分享/排他性(
) “合并”例如
XLOCK可以根据需要独占锁定行。 ROWLOCK / PAGELOCK不会。