数据库-事务并发操作问题及并发的控制
事务并发操作出现几种问题
所谓事务,是用户定义的一个数据库操作序列,是数据库环境中的逻辑工作单元,
是一个不可分割的整体。
事务的这个4个特性简称为ACID特性,事务ACID特性可能遭到破坏的因素有:
①多个事务并发执行,不同事务的操作交叉执行;
②事务在运行过程中被强行终止。
如何保证在多个事务并发执行的过程中不发生上述的两种情况,是数据库管理系统并发
控制的主要责任。
丢失修改数据
举例:银行卡有100元,事务A取10元,事务B取10元,事务AB两人同时取钱,初始
值都是100
读“脏”数据
数据库技术中,如果正常提交的事务A使用了事务B未提交的撤销数据,这种数据成
为“脏数据”,会造成数据的脏读和污读。
不一致分析
时,另一个事务正在修改同一个数据。这样就可能导致两个事务的相互干扰及“读”事务的
错误执行结果。
数据库并发的控制(了解部分)
并发调度的可串行化
可串行化准则:多个事务的并发执行时正确的,当且仅当其结果按某一次序串
行执行它们时的结果相同,这种调度策略称为可串行化调度。可串行化是并发事务正确
性的准则,一个给定的并发调度,当且仅当它是可串行化的,才认为是正确的。
封锁
封锁是实现并发控制的非常重要的技术。封锁是指某事务在对某数据对象进行操作以
前,先请求系统对其加锁,成功加锁之后该事务就对该数据对象有了控制权,只有该事
务对其进行解锁之后,其他的事务才能更新它,DBMS有两种锁:
① 排它锁(也称作X锁)
如果事务T在对某个数据对象实施了X锁,那么其他的事务必须要等到T事务接触对该
数据对象的X锁之后,才能对这个数据进行加锁。
② 共享锁(也称作S锁)
如果事务T在对某个数据对象实施了S锁,那么其他的事务也能对该数据对象实施S
锁,但是对这个数据对象施加的所有S锁都接触之前不允许任何事务对该数据对象实施X
锁。
死锁
封锁技术可以避免一些并发操作引起的不一致错误,但也会产生其他的一些问题,
活锁和死锁。
① 活锁
如果某个事务处在永远等待的状态,得不到封锁的机会,这种现象为活锁,避免这种锁
最好的方法就是采用先来先服务的策略。
② 死锁
两个或两个以上的事务都处于等待状态每个事务都在等待对方事务接触封锁,它才能继
续执行下去,这样任何事务都处于等待状态而无法继续执行的现象称为死锁
解决死锁问题方法有两类:
A、 死锁的预防
B、 死锁的诊断与预防
数据库-事务并发操作问题及并发的控制相关推荐
- 并发事务正确性的准则 可串行化_从0到1理解数据库事务(上):并发问题与隔离级别...
最近准备写一篇关于Spanner事务的分享,所以先分享一些基础知识,涉及ACID.隔离级别.MVCC.锁,由于太长,只好拆分成上下两篇: 上:并发问题与隔离级别 主要讲事务所要解决的问题.思路,先理解 ...
- 支持串行隔离级别_从0到1理解数据库事务(上):并发问题与隔离级别
最近准备写一篇关于Spanner事务的分享,所以先分享一些基础知识,涉及ACID.隔离级别.MVCC.锁,由于太长,只好拆分成上下两篇: 上:并发问题与隔离级别 主要讲事务所要解决的问题.思路,先理解 ...
- 关于使用Transaction对于非数据库事务的操作
在操作数据库的过程中,为了数据的一致性,我们可以使用Transaction,要么成功的时候全部提交,要么有任何一个操作失败立即全部回滚.不仅仅是在数据库方面,有时候操作其他的内容,比如说对于系统文件的 ...
- 数据库事务的四大特性及事务隔离级别
概要: 事务的四个特性:原子性.一致性.隔离性.持久性 事务不隔离带来的问题:更新丢失.脏读.不可重复读.虚读(幻读).其中更新丢失就是并发写,这是一定不允许的,因此一定要解决更新丢失问题. 事务隔离 ...
- 数据库事务原理及并发、死锁
1. 什么是数据库事务 1.1 数据库事务是指作为单个逻辑工作单元执行的一系列操作(SQL语句).这些操作要么全部执行,要么全部不执行. 1.2 通过ACID实现数据库事务模型 1.2.1 原子性(A ...
- 【转载】并发操作会带来哪些数据不一致性(数据库)
事务是并发控制的基本单位,保证事务的ACID特性是事务处理的重要任务,而事务ACID特性可能遭到破坏的原因之一就是多个事务对数据库的并发操作造成的. 并发操作带来的数据不一致性有:丢失修改,不可重复读 ...
- 简述数据库事务并发机制
转载:https://blog.csdn.net/justloveyou_/article/details/70312810 事务是最小的逻辑执行单元,也是数据库并发控制的基本单位,其执行的结果必须使 ...
- 15张图呈现数据库事务背后的并发原理
本文分享自华为云社区<将数据库9种锁.3种读.4种隔离级别一次性串联起来,用15张图呈现背后数据库事务背后的并发原理>,作者: breakDawn. 前段时间开发时,正好遇到了2个进程同时 ...
- c++并发操作mysql_文件数据库sqlite3 C++ 线程安全和并发
一.SQLite与线程 SQLite 是线程安全的. 线程模型 SQLite 支持如下三种线程模型 单线程模型 这种模型下,所有互斥锁都被禁用,同一时间只能由一个线程访问. 多线程模型 这种模型下,一 ...
最新文章
- 产品设计体会(1011)少做就是多做
- java字符串数组拷贝函数_java 数组的拷贝 对象数组的拷贝 System.arraycopy函数
- javascript中三个等号的意思
- nginx 安装禅道
- TLS/SSL测试工具
- 服务器应用服务为何卡顿?原来是内存耗尽惹的祸!
- html5中figure怎么用,figure 和 figcaption 元素的正确使用方式
- 后端同同不肯给我算好的时间差给我,只好自己写了:
- PTA5-1 最大子列和问题
- 沙迦美国大学科研副校长赵伟:揭秘工业 4.0 核心技术 CPS 的前世今生 | 人物志...
- jest单元测试-作用域
- GPS测量中所涉及的时间系统
- 金税盘显示frm000013_开票软件(金税盘版)2020年4月征期抄报方法/季报方法!
- 免费抽奖---PMP续证PDU | PMP知识地图.
- 固定链接设置朴素正常html无法显示,wordpress固定链接设置修改常见问题
- 利用css画三角箭头图标
- 爱普生Epson Stylus SX235W 一体机驱动
- css button阴影效果,css怎么给button设置阴影
- Rabbit and Grass --- 组合博弈 GS函数 记录
- IROS2020开源软硬件!多激光雷达的协同定位建图及在线外参自标定