欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQL Server三种锁定模式的知识讲解

程序员文章站 2022-09-08 19:34:58
sql server 锁定模式有三种:共享( s锁),更新(u锁),排他(x锁); s锁是共享锁,如果事务t对数据a加上共享锁后,则其他事务只能对a再加共享锁,不能加排他...

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要用独占,不然的话乱套了;这是为了保护数据再一次操作中的准确性;

个人理解就是,一次一个....

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接