我已经从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
解决方法
原文地址:https://www.jb51.cc/mssql/84058.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。