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是粒度 粒度和隔离级别和模式是正交的. >粒度=锁定的内容=行,页,表(PAGLOCK,ROWLOCK,TABLOCK) XLOCK可以根据需要独占锁定行. ROWLOCK / PAGELOCK不会. (编辑:天瑞地安资讯网_保定站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- sql-server – SQL Server中的分页
- sql-server – 查看链接服务器依赖项sql server 2008
- 在SQL Server存储过程中按索引而不是名称访问表的列
- sql-server – 构建内部自定义VoIP网关的成本?
- sql – 登录失败.登录来自不受信任的域,不能与Windows身份验
- sql-server – 如何在DST之前或之后的日期获得UTC与本地时间
- sql-server – 将每日时间表分组为[开始日期;结束日期]与工
- 如何将auto_increment键插入SQL Server表
- sql-server – SQLCMD命令无法插入重音符
- sql-server – 使用SQL登录登录时出现SQL Server错误
- sql-server – 现有的DAO代码是否适用于SQL Serv
- sql-server – 如果是肯定的,请汇总所有项目.如果
- sql-server – sys.databases中某些列的排序规则
- sql-server – SQL Server CASE语句是否评估所有
- sql的存储过程定义有哪些方法,你知道几种?
- sql-server – SQL Server需要分区数据,但只有标
- sql-server – 5个大型数据库的驱动器配置
- sql – 如何组合来自两个存储过程调用的结果集?
- .net – 数据库本地化 – 查找列表 – 更智能的方
- sql-server-2008 – 如何使用SQL Server DDL进行

