MSSql Server事务和锁研究

来源:互联网 发布:淘宝抢购怎样抢的快 编辑:程序博客网 时间:2024/06/01 11:31

锁:主要指共享锁和排他锁两种经常用到的锁。

隔离级别:设置在事务上的,共享锁的锁定时间与事务的隔离级别有关。update和delete默认都发出排他锁。

隔离级别

脏读

不可重复读取

幻像

说明

未提交读(read uncommitted)

如果其他事务更新,不管是否提交,立即执行

提交读(read committed默认)

读取提交过的数据。如果其他事务更新没提交,则等待

可重复读(repeatable read)

查询期间,不允许其他事务update

可串行读(serializable)

查询期间,不允许其他事务insertdelete



锁提示:在执行SQL语句的时候查询语句发出什么样的锁,这就由事务的隔离级别决定了。一般情况,读语句(select)发出共享锁,写语句(update,insert,delete)发出排他锁。但是,如果想改变sql语句发出的锁怎么办呢,SQLserver为我们提供了锁定提示的概念。


锁定提示对SQL语句进行特别指定,这个指定将覆盖事务的隔离级别,相当于是对默认锁状态的一个补充,可以对每条语句的锁级别进行覆盖操作。

主要类型有:

类型1

①     READUNCOMMITTED:不发出锁

②     READCOMMITTED:发出共享锁,保持到读取结束

③     REPEATABLEREAD:发出共享锁,保持到事务结束

④     SERIALIZABLE:发出共享锁,保持到事务结束

类型2

①     NOLOCK:不发出锁。等同于READUNCOMMITTED

②     HOLDLOCK:发出共享锁,保持到事务结束。等同于SERIALIZABLE

③     XLOCK:发出排他锁,保持到事务结束。

④     UPDLOCK:发出更新锁,保持到事务事务结束。(更新锁:不阻塞别的事物,允许别的事物读数据(即更新锁可与共享锁兼容),但他确保自上次读取数据后数据没有被更新)

⑤     READPAST:发出共享锁,但跳过锁定行,它不会被阻塞。适用条件:提交读的隔离级别,行级锁,select语句中。

类型3

①     ROWLOCK:行级锁

②     PAGLOCK:页级锁

③     TABLOCK:表锁

④     TABLOCKX:表排他锁

引用自http://www.cnblogs.com/qanholas/archive/2012/01/04/2312248.html
0 0