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

作者:chenqiangdage 时间:2024-01-17 19:30:11 

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

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

来源:https://blog.csdn.net/chenqiangdage/article/details/19357549

标签:sql,server,锁
0
投稿

猜你喜欢

  • mysql 8.0.12 安装配置方法并修改密码

    2024-01-19 14:49:05
  • pytorch通过训练结果的复现设置随机种子

    2021-04-19 07:58:53
  • Python opencv图像基本操作学习之灰度图转换

    2023-02-17 09:04:43
  • golang 两个go程轮流打印一个切片的实现

    2024-02-12 09:11:29
  • asp如何判断一个电子信箱格式是否有效?

    2010-01-12 20:18:00
  • Python pymysql向SQL语句中传参的多种方法

    2024-01-13 05:10:00
  • 一步一步教你网站同步镜像(转载)

    2024-01-21 03:38:11
  • MySQL 通过索引优化含ORDER BY的语句

    2010-03-25 10:28:00
  • python输出100以内的质数与合数实例代码

    2021-01-30 20:47:52
  • Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案

    2024-05-02 17:09:28
  • python 从文件夹抽取图片另存的方法

    2022-08-26 13:00:55
  • PHP MVC框架中类的自动加载机制实例分析

    2023-11-04 09:18:09
  • vue 开发一个按钮组件的示例代码

    2024-04-30 10:27:40
  • vuex实现数据状态持久化

    2024-04-30 10:34:38
  • tween.js缓动补间动画算法示例

    2024-05-21 10:13:40
  • Python之进行URL编码案例讲解

    2023-03-31 03:46:58
  • Python PyMySQL操作MySQL数据库的方法详解

    2024-01-21 17:44:24
  • python文件和目录操作函数小结

    2022-02-21 21:45:23
  • vuex管理状态仓库使用详解

    2024-04-30 10:38:33
  • Django实现简单网页弹出警告代码

    2022-12-31 06:56:16
  • asp之家 网络编程 m.aspxhome.com