锁:主要指共享锁和排他锁两种经常用到的锁。
隔离级别:设置在事务上的,共享锁的锁定时间与事务的隔离级别有关。update和delete默认都发出排他锁。
隔离级别 | 脏读 | 不可重复读取 | 幻像 | 说明 |
未提交读(read uncommitted) | 是 | 是 | 是 | 如果其他事务更新,不管是否提交,立即执行 |
提交读(read committed默认) | 否 | 是 | 是 | 读取提交过的数据。如果其他事务更新没提交,则等待 |
可重复读(repeatable read) | 否 | 否 | 是 | 查询期间,不允许其他事务update |
可串行读(serializable) | 否 | 否 | 否 | 查询期间,不允许其他事务insert或delete |
锁提示: 在执行 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