sql-server – SQL Server ROWLOCK over SELECT如果不存在INSERT
发布时间:2020-12-12 06:06:32 所属栏目:MsSql教程 来源:网络整理
导读:我已经从SQL Server 2005升级到2008.我记得在2005年,ROWLOCK根本无法工作,我不得不使用PAGELOCK或XLOCK来实现任何类型的实际锁定.我知道读者会问“你做错了什么?”没有.我最终证明我可以编辑一个“ROWLOCKED”行,但如果我升级锁定级别则不行.我没有机会看到
我已经从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是粒度 粒度和隔离级别和模式是正交的. >粒度=锁定的内容=行,页,表(PAGLOCK,ROWLOCK,TABLOCK) XLOCK可以根据需要独占锁定行. ROWLOCK / PAGELOCK不会. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- SQLServer查看备份文件信息
- r – 如何使用st_join()使用sf包进行空间连接
- linux系统下实现mysql热备份详细步骤(mysql主从复
- SQLServer 中dm_os_ring_buffers(ring_buffer_co
- SqlServer建立存储过程,方便.NET插入自增字段
- Microsoft SQL Server 2012 数据库安装图解教程
- sql-server – 如何在SQL Compact Edition中导入
- 实现基于SQLServer存储账号的MDaemon群集
- sql-server – SSRS:在每行上重复tablix最左边的
- SQLServer字符串批量拆分得方法
热点阅读