用例子来说明SQL Server的更新锁

时间:2022-01-18 03:47:15

1:首先创建表,插入数据:

create table table1(A nchar(10) not null primary key,B nchar(10),C nchar(10));

insert into table1(A,B,C) values('a1','b1','c1');
insert into table1(A,B,C) values('a2','b2','c2');

insert into table1(A,B,C) values('a3','b3','c3');

2:打开一个sqlserver的查询窗口,执行下面的代码(使用了更新锁)

begin tran
select * from table1(updlock) 
waitfor delay '00:00:30' --等待30秒
update table1 set B='bb' where A='a2'
commit tran


3:打开第二个查询窗口,执行下面的代码。(使用了更新锁)

begin tran
select * from table1(updlock) 
commit tran

4:打开第三个查询窗口,执行下面的代码(不使用更新锁)

begin tran
select * from table1
commit tran

5:测试结果,更新锁与更新锁互斥,第二个查询窗口的查询语句要等第一个的事务执行完才会运行,第三个是共享锁,共享锁和更新锁不互斥,第三个查询可以运行,不用等待第一个事务执行完。

截图如下:

1)第一查询窗口:

用例子来说明SQL Server的更新锁


2)第二个查询窗口:

用例子来说明SQL Server的更新锁


3:第三个查询窗口:

用例子来说明SQL Server的更新锁



6:提一个问题,如何在java程序中实现更新锁呢?