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

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

总结

更多相关文章

  1. Android系统配置数据库注释(settings.db)
  2. Android——Activity四种启动模式
  3. 【安卓笔记】android客户端与服务端交互的三种方式
  4. 固定屏幕显示模式 ScreenOrientation
  5. 解决Android编辑框在全屏模式下无法检测布局变化的问题
  6. 转:Android下文件操作模式(含SDCard的读写)
  7. Android(安卓)AOSP输入法(LatinIME)大写判断分析
  8. android中和c++中生产者和消费者模式
  9. android优化工具

随机推荐

  1. 未能解决:com.google.android.gms:play-s
  2. java 访问控制修饰符总结详解
  3. java如何通过反射 激活静态类的静态方法
  4. Java怎么实现保存页面内容 导出为图片到
  5. java远程类加载与轻客户端
  6. Java核心技术 卷一(序言+0-5)
  7. java通过poi模板导出excel
  8. 在Linux上生成java程序的火焰图
  9. R.java was modified manually! Revertin
  10. 使用多个联合查询选择post java 8