sql-server – 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

解决方法

一个解释…

> ROWLOCK / PAGELOCK是粒度
> XLOCK是模式

粒度和隔离级别和模式是正交的.

>粒度=锁定的内容=行,页,表(PAGLOCK,ROWLOCK,TABLOCK)
>隔离级别=锁定持续时间,并发性(HOLDLOCK,READCOMMITTED,REPEATABLEREAD,SERIALIZABLE)
>模式=共享/排他性(UPDLOCK,XLOCK)
>“合并”,例如NOLOCK,TABLOCKX

XLOCK可以根据需要独占锁定行. ROWLOCK / PAGELOCK不会.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...