锁:主要指共享锁和排他锁两种经常用到的锁。
隔离级别:设置在事务上的,共享锁的锁定时间与事务的隔离级别有关。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
本文详细介绍了SQL中的锁机制,包括共享锁和排他锁,并深入探讨了四种不同的事务隔离级别:未提交读、提交读、可重复读及可串行读。此外,还解释了如何通过锁定提示来调整SQL语句的锁行为。
514

被折叠的 条评论
为什么被折叠?



