谈谈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才能修改

posted @ 2009-03-18 14:45  ITAres  阅读(1320)  评论(1)    收藏  举报