sqlserver 锁定一行数据,禁止读取,修改和删除

sql 事务中 有时候需要锁定某行,等事物完成后 释放此行。


使用 with(ROWLOCK,UpdLock)   锁定当前行。禁止读取,修改删除


a 事务

ALTER PROCEDURE [dbo].[asuo]

AS
BEGIN


 begin tran
SELECT TOP 1 * FROM dbo.JYQ_HLT_Order with(ROWLOCK,UpdLock)  WHERE orderID=321878
UPDATE dbo.JYQ_HLT_Order SET orderBillingstatus=13   WHERE orderID=321878
SELECT TOP 1 * FROM dbo.JYQ_HLT_Order  WHERE orderID=321878
waitfor delay '00:00:10'
 COMMIT TRAN
END


b 事务


ALTER PROCEDURE [dbo].[bsuo]

AS
BEGIN
 begin tran
UPDATE dbo.JYQ_HLT_Order SET orderBillingstatus=14   WHERE orderID=321878
SELECT TOP 1 * FROM dbo.JYQ_HLT_Order  WHERE orderID=321878
 COMMIT TRAN
END



b事务等待 a事务 COMMIT TRAN 后 才会执行。

with(ROWLOCK)任何作用

with(ROWLOCK,UpdLock)   必须组合使用才可以生效

相关文章

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跟踪的数据库标...