MSSql Server事务和锁研究

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

隔离级别:设置在事务上的,共享锁的锁定时间与事务的隔离级别有关。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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值