谈谈mssql的锁机制
谈谈mssql的锁机制
SET TRANSACTION ISOLATION LEVEL
控制由连接发出的所有 MSSQL SELECT 语句的默认事务锁定行为。
语法
SET TRANSACTION ISOLATION LEVEL
{ READ COMMITTED
| READ UNCOMMITTED
| REPEATABLE READ
| SERIALIZABLE
}
参数
READ COMMITTED
指定在读取数据时控制共享锁以避免脏读,但数据可在事务结束前更改,从而产生不可重复读取或幻像数据。该选项是 SQL Server 的默认值。
READ UNCOMMITTED
执行脏读或 0 级隔离锁定,这表示不发出共享锁,也不接受排它锁。
REPEATABLE READ
锁定查询中使用的所有数据以防止其他用户更新数据,但是其他用户可以将新的幻像行插入数据集,且幻像行包括在当前事务的后续读取中。因为并发低于默认隔离级别,所以应只在必要时才使用该选项。
SERIALIZABLE
在数据集上放置一个范围锁,以防止其他用户在事务完成之前更新数据集或将行插入数据集内。这是四个隔离级别中限制最大的级别。因为并发级别较低,所以应只在必要时才使用该选项。该选项的作用与在事务内所有 SELECT 语句中
的所有表上设置 HOLDLOCK 相同。
注释
一次只能设置这些选项中的一个,而且设置的选项将一直对那个连接保持有效,直到显式更改该选项为止。
这是默认行为,除非在语句的 FROM 子句中在表级上指定优化选项。
SET TRANSACTION ISOLATION LEVEL 的设置是在执行或运行时设置,而不是在分析时设置。
示例如下:
READ COMMITTED
conn1:
BEGIN TRAN ttt
update account set username='itares' where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
select * from account where userid=1;
当运行conn1时,事务conn2需要等待1提交后才能运行。
conn1:
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN ttt
select * from account where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
update account set username='itares' where userid=1;
当运行conn1时,conn2可以运行
conn1:
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN ttt
select * from account where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
insert into account values(2,'itares')
当运行conn1时,conn2可以运行
REPEATABLE READ
conn1:
SET TRANSACTION ISOLATION REPEATABLE READ
BEGIN TRAN ttt
select * from account where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
update account set username='itares' where userid=1;
需要等待conn1完成后conn2才能修改
conn1:
SET TRANSACTION ISOLATION REPEATABLE READ
BEGIN TRAN ttt
select * from account;
waitfor delay '00:00:20'
commit tran ttt
conn2:
insert into account values(2,'itares')
当运行conn1时,conn2可以运行
SERIALIZABLE
conn1:
BEGIN TRAN ttt
update account set username='itares' where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
select * from account where userid=1;
需要等待conn1完成后conn2才能读取
conn1:
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN ttt
select * from account where userid=1;
waitfor delay '00:00:20'
commit tran ttt
conn2:
update account set username='itares' where userid=1;
需要等待conn1完成后conn2才能修改
conn1:
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN ttt
select * from account;
waitfor delay '00:00:20'
commit tran ttt
conn2:
insert into account values(2,'itares')
需要等待conn1完成后conn2才能修改


浙公网安备 33010602011771号