SQL Server三种锁定模式的知识讲解
sql server 锁定模式有三种:共享( S锁),更新(U锁),排他(X锁);
S锁是共享锁,如果事务T对数据A加上共享锁后,则其他事务只能对A再加共享锁,不能加排他锁。获准共享锁的事务只能读数据,不能修改数据。
个人理解为,对数据A的操作就只能是SELECT ,(联想下,S锁,不就是Select的首字母么),其他事务对A数据的UPDATE ,DELETE都不能进行;
U锁是更新锁。用于可更新的资源中。防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。
原理解释:
更新锁
更新 (U) 锁可以防止通常形式的死锁。一般更新模式由一个事务组成,此事务读取记录,获取资源(页或行)的共享 (S) 锁,然后修改行,此操作要求锁转换为排它 (X) 锁。
如果两个事务获得了资源上的共享模式锁,然后试图同时更新数据,则一个事务尝试将锁转换为排它 (X) 锁。
共享模式到排它锁的转换必须等待一段时间,因为一个事务的排它锁与其它事务的共享模式锁不兼容;发生锁等待。
第二个事务试图获取排它 (X) 锁以进行更新。
由于两个事务都要转换为排它 (X) 锁,并且每个事务都等待另一个事务释放共享模式锁,因此发生死锁。
若要避免这种潜在的死锁问题,请使用更新 (U) 锁。一次只有一个事务可以获得资源的更新 (U) 锁。
如果事务修改资源,则更新 (U) 锁转换为排它 (X) 锁。否则,锁转换为共享锁。
个人理解,打个比方,A,B都拿把枪指着对方说:”我等你放下枪我就放下枪“,大家都等对方放下枪,于是就这么死僵持着......
X锁是排他锁,也叫独占锁,事务对A资源的insert ,update ,delete要用独占,不然的话乱套了;这是为了保护数据再一次操作中的准确性;
个人理解就是,一次一个....
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:
- apache 三种工作模式的讲解
- 图文并茂讲解VMware三种网络模式
- Vmware中提供的与网络通讯的三种网络模式的讲解:Bridge、NAT 、host-only
- 图文并茂讲解VMware三种网络模式
- SQL Server 索引基础知识(10)----Join 时的三种算法简介
- 常见浏览器兼容问题、盒模型2种模式以及css hack知识讲解
- Vmware中提供的与网络通讯的三种网络模式的讲解
- LVS原理讲解(三种工作模式和8种调度算法)
- Linux Apache的深度优化及三种工作模式的讲解
- 讲解delegate,notifucation,KVO三种模式实现通信的优缺
- java基础知识回顾---单例模式的三种实现
- 转 一篇关于sql server 三种恢复模式的文章,从sql server 的机制上来写的,感觉很不错,转了
- 图文并茂讲解VMware三种网络模式
- Sql Server 三种事务模式
- 【python基础知识】文件操作中的读写模式讲解
- apache 三种工作模式的讲解
- SQL Server 索引基础知识(10)----Joins 时的三种算法简介
- 浅谈SQL Server中的事务日志和三种恢复模式
- 图文并茂讲解VMware三种网络模式
- SQL Server 索引基础知识(10)----Join 时的三种算法简介(转自蝈蝈俊.net)