锁的类型-

简介: 锁的类型-

  所谓封锁,就是一个事务可向系统提出请求,对被操作的数据加锁(Lock)。其他事务必须等到此事务解锁(Unlock)之后才能访问该数据。从而,在多个用于并发访问数据库时,确保不互相干扰,可锁定的单位是:行、页、表、盘区和数据库。

锁的类型

   1.共享(S)锁:用于读操作

       多个事务可封锁一个共享单位的数据

       任何事务不能修改加S锁的数据

       通常是加S锁的数据被读取完毕,S锁立即被释放

     2.独占(X)锁:用手写操作

        仅允许一个事务封锁此共享数据

        其他任何事务必须等到X锁被释放才能对该室上速句进行访问

        X锁一直到事务结束才能被释放

      3.更新(U)锁

        用来预定要对此页施加X锁,它允许其他事务读,但不允许再施加U锁或X锁

死锁

所谓死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去,此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程

  由于资源占用是互斥的,当某个进程提出申请资源后,使得有关进程在无外力协助下,永远分配不到必须得资源而无法继续进行,这就产生了一种特殊现象死锁

一种情形,此时执行 程序中两个或多个线程发色会给你永久堵塞(等待),每个线程都在等待被其他线程占用并堵塞了的资源。例如,如果线程A锁住了记录1并等待记录2,而线程B锁住了记录2等待记录1,这样两个线程就发生了死锁现象。

必要条件

  1. 互斥条件:一个资源每次只能被一个进程使用
  2. 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放
  3. 不剥夺条件:进程已获得的资源,在未使用完之前,不能强行剥夺
  4. 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系

这四个条件是死锁的必要条件,质押系统发生死锁,这些条件必然成立,而只要上述之一不满足,就不会发生死锁。

死锁的解除和预防

   按统一顺序访问对象

   避免事务中的用户交互

   保持事务简短并在一个批处理中

   使用低隔离级别

   使用绑定

死锁的建议

  1. 对于频繁使用的表使用集簇化的索引
  2. 设法避免一次性影响大量记录的T-SQL语句,特点INSERT和UPSAE语句
  3. 设法让UPDATE 和DELETE语句使用索引
  4. 使用嵌套事务时,避免提交和回退冲突
  5. 对一些数据不需要及时读取更新值的表在SQL的时候在表后台加上(nolock),如:Select * from tableA(nolock)


目录
相关文章
|
JSON 网络协议 Dubbo
RPC框架(技术总结)
RPC框架(技术总结)
RPC框架(技术总结)
|
10月前
|
测试技术 API 开发者
通义千问Qwen2.5-Max登上大模型盲测榜单全球前十,数学及编程能力夺冠
通义千问Qwen2.5-Max登上大模型盲测榜单全球前十,数学及编程能力夺冠
|
监控 安全 关系型数据库
稳定性之故障应急处理流程
尽管可以通过稳定性体系建设,来避免出现生产系统故障。但是仍然无法彻底避免一点风险都不会产生,当稳定性风险产生后,怎么快速协调组织,缩短故障时长,科学的流程呢?
稳定性之故障应急处理流程
|
安全 网络安全
ISO/IEC 27001 信息安全管理体系认证
一、 信息安全管理体系标准业务介绍 1、 背景介绍   信息作为组织的重要资产,需要得到妥善保护。但随着信息技术的高速发展,特别是Internet的问世及网上交易的启用,许多信息安全的问题也纷纷出现:系统瘫痪、黑客入侵、病毒感染、网页改写、客户资料的流失及公司内部资料的泄露等等。
3074 0
|
编解码 计算机视觉 Windows
会声会影最新版2023新增功能及配置要求
可能大家已经看到网络上关于会声会影2023新版的一些消息,甚至还有人放出了安装包,这里提醒一下各位粉丝不要心急,今天coco玛奇朵在这里分享2023新版公布信息及下载。会声会影2023中文版功能非常强大的视频编辑软件,非常专业的使用效果,会声会影2023中文版可以针对剪辑电影进行使用,非常强大的色彩校正方式,无论什么光线下进行拍摄,都可以通过后期进行调整,并且里面超多不同的专场设置,能够让你的视频变得更加自然,不会出现非常生硬的专场,强大的编辑器可以下载免费使用。
674 0
|
人工智能 移动开发 算法
王道考研操作系统同步与互斥(王道大题详解)(一)
王道考研操作系统同步与互斥(王道大题详解)(一)
575 1
王道考研操作系统同步与互斥(王道大题详解)(一)
|
存储 数据采集 缓存
数据标定内容的存储和读取
数据标定内容的存储和读取
数据标定内容的存储和读取
|
设计模式 领域建模 数据库
DDD领域驱动设计落地实践系列:初识DDD
笔者在经历的很多项目中都使用了DDD领域驱动设计进行架构设计,尤其是在业务梳理、中台规划以及微服务划分等方面,DDD是重要的架构设计方法论,对平时的架构设计有非常好的指导作用。从本文开始笔者将通过一系列的文章阐述自己对于DDD的理解以及如何在项目实战中落地实践DDD。本文作为系列文章的开端,主要和大家聊聊DDD的一些基本概念以及常用方法。
DDD领域驱动设计落地实践系列:初识DDD
|
机器学习/深度学习
【深度学习】2-模型在测试集的准确率大于训练集
【深度学习】2-模型在测试集的准确率大于训练集
1278 0
【深度学习】2-模型在测试集的准确率大于训练集
|
数据安全/隐私保护 Python
Python操作PDF全总结|pdfplumber&PyPDF2
Python操作PDF全总结|pdfplumber&PyPDF2
713 0