位置: 编程技术 - 正文

MySQL中事务概念的简洁学习教程(mysql中事务的作用)

编辑:rootadmin

推荐整理分享MySQL中事务概念的简洁学习教程(mysql中事务的作用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql事务的概念,mysql中事务的作用,mysql中的事务,mysql事务的概念,mysql中事务是指什么,mysql 事务的实现原理,mysql事务的概念,mysql事务的概念,内容如对您有帮助,希望把文章链接给更多的朋友!

事务是由一步或几步数据库操作序列组成逻辑执行单元,这系列操作要么全部执行,要么全部放弃执行。程序和事务是两个不同的概念。一般而言:一段程序中可能包含多个事务。

事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)。这四个特性也简称ACID性。

1)原子性:事务是应用中最小的执行单位,就如原子是自然界最小颗粒,具有不可再分的特征一样。事务是应用中不可再分的最小逻辑执行体。

2)一致性:事务执行的结果,必须使数据库从一个一致性状态,变到另一个一致性状态。当数据库中只包含事务成功提交的结果时,数据库处于一致性状态。一致性是通过原子性来保证的。

3)隔离性:各个事务的执行互不干扰,任意一个事务的内部操作对其他并发的事务,都是隔离的。也就是说:并发执行的事务之间不能看到对方的中间状态,并发执行的事务之间不能相互影响。

4)持续性:持续性也称为持久性,指事务一旦提交,对数据所做的任何改变,都要记录到永久存储器中,通常是保存进物理数据库。

在关系型数据库中,事务的隔离性分为四个隔离级别,在解读这四个级别前先介绍几个关于读数据的概念。

1)脏读(Dirty Reads):所谓脏读就是对脏数据(Drity Data)的读取,而脏数据所指的就是未提交的数据。也就是说,一个事务正在对一条记录做修改,在这个事务完成并提交之前,这条数据是处于待定状态的(可能提交也可能回滚),这时,第二个事务来读取这条没有提交的数据,并据此做进一步的处理,就会产生未提交的数据依赖关系。这种现象被称为脏读。

2)不可重复读(Non-Repeatable Reads):一个事务先后读取同一条记录,但两次读取的数据不同,我们称之为不可重复读。也就是说,这个事务在两次读取之间该数据被其它事务所修改。

3)幻读(Phantom Reads):一个事务按相同的查询条件重新读取以前检索过的数据,却发现其他事务插入了满足其查询条件的新数据,这种现象就称为幻读。

事务四个隔离级别对比:

1)未提交读(Read Uncommitted):SELECT语句以非锁定方式被执行,所以有可能读到脏数据,隔离级别最低。

2)提交读(Read Committed):只能读取到已经提交的数据。即解决了脏读,但未解决不可重复读。

3)可重复读(Repeated Read):在同一个事务内的查询都是事务开始时刻一致的,InnoDB的默认级别。在SQL标准中,该隔离级别消除了不可重复读,但是还存在幻读。

4)串行读(Serializable):完全的串行化读,所有SELECT语句都被隐式的转换成SELECT ... LOCK IN SHARE MODE,即读取使用表级共享锁,读写相互都会阻塞。隔离级别最高。

隔离级别对比表:

数据库的事务有下列语句组成:

一组DML(Data Manipulate Language,即数据操作语言)经过这组DML修改后数据将保持较好的一致性。

一个DDL(Data Definition Language,即数据定义语言)语句。

一个DCL(Data control Language,即数据控制语言)语句。

DDL和DCL语句最多只能有一个,因为DDL和DCL语句都会导致事务立即提交。

当事务所包含的全部数据库操作都成功执行后,应该提交(commit)事务,使这些修改永久生效。

事务提交有两种方式:显式提交和自动提交。

(1)显式提交:使用commit。

(2)自动提交:执行DDL或DCL,或者程序正常退出。

MySQL中事务概念的简洁学习教程(mysql中事务的作用)

数据库事务传播级别,指的是事务嵌套时,应该采用什么策略,即在一个事务中调用别的事务,该怎么办

假如有一下两个事务:

1 : PROPAGATION_REQUIRED

加入当前正要执行的事务不在另外一个事务里,那么就起一个新的事务

比如说, ServiceB.methodB 的事务级别定义为 PROPAGATION_REQUIRED, 那么由于执行 ServiceA.methodA 的时候,

ServiceA.methodA 已经起了事务,这时调用 ServiceB.methodB , ServiceB.methodB 看到自己已经运行在 ServiceA.methodA

的事务内部,就不再起新的事务。而假如 ServiceA.methodA 运行的时候发现自己没有在事务中,他就会为自己分配一个事务。

这样,在 ServiceA.methodA 或者在 ServiceB.methodB 内的任何地方出现异常,事务都会被回滚。即使 ServiceB.methodB 的事务已经被

提交,但是 ServiceA.methodA 在接下来 fail 要回滚, ServiceB.methodB 也要回滚

2 : PROPAGATION_SUPPORTS

如果当前在事务中,即以事务的形式运行,如果当前不再一个事务中,那么就以非事务的形式运行

3 : PROPAGATION_MANDATORY

必须在一个事务中运行。也就是说,他只能被一个父事务调用。否则,他就要抛出异常

4 : PROPAGATION_REQUIRES_NEW

这个就比较绕口了。 比如我们设计 ServiceA.methodA 的事务级别为 PROPAGATION_REQUIRED , ServiceB.methodB 的事务级别为 PROPAGATION_REQUIRES_NEW ,

那么当执行到 ServiceB.methodB 的时候, ServiceA.methodA 所在的事务就会挂起, ServiceB.methodB 会起一个新的事务,等待 ServiceB.methodB 的事务完成以后,

他才继续执行。他与 PROPAGATION_REQUIRED 的事务区别在于事务的回滚程度了。因为 ServiceB.methodB 是新起一个事务,那么就是存在

两个不同的事务。如果 ServiceB.methodB 已经提交,那么 ServiceA.methodA 失败回滚, ServiceB.methodB 是不会回滚的。如果 ServiceB.methodB 失败回滚,

如果他抛出的异常被 ServiceA.methodA 捕获, ServiceA.methodA 事务仍然可能提交。

5 : PROPAGATION_NOT_SUPPORTED

当前不支持事务。比如 ServiceA.methodA 的事务级别是 PROPAGATION_REQUIRED ,而 ServiceB.methodB 的事务级别是 PROPAGATION_NOT_SUPPORTED ,

那么当执行到 ServiceB.methodB 时, ServiceA.methodA 的事务挂起,而他以非事务的状态运行完,再继续 ServiceA.methodA 的事务。

6 : PROPAGATION_NEVER

不能在事务中运行。假设 ServiceA.methodA 的事务级别是 PROPAGATION_REQUIRED , 而 ServiceB.methodB 的事务级别是 PROPAGATION_NEVER ,

那么 ServiceB.methodB 就要抛出异常了。

7 : PROPAGATION_NESTED

理解 Nested 的关键是 savepoint 。他与 PROPAGATION_REQUIRES_NEW 的区别是, PROPAGATION_REQUIRES_NEW 另起一个事务,将会与他的父事务相互独立,

而 Nested 的事务和他的父事务是相依的,他的提交是要等和他的父事务一块提交的。也就是说,如果父事务最后回滚,他也要回滚的。

而 Nested 事务的好处是他有一个 savepoint 。

Windows下MySQL日志基本的查看以及导入导出用法教程 MYSQL有不同类型的日志文件(各自存储了不同类型的日志),从它们当中可以查询到MYSQL里都做了些什么,对于MYSQL的管理工作,这些日志文件是不可缺少的

MySQL中使用or、in与union all在查询命令下的效率对比 OR、in和unionall查询效率到底哪个快?网上很多的声音都是说unionall快于or、in,因为or、in会导致全表扫描,他们给出了很多的实例。但真的unionall真的快

MySQL下使用Inplace和Online方式创建索引的教程 MySQL各版本,对于addIndex的处理方式是不同的,主要有三种:(1)CopyTable方式这是InnoDB最早支持的创建索引的方式。顾名思义,创建索引是通过临时表拷

标签: mysql中事务的作用

本文链接地址:https://www.jiuchutong.com/biancheng/312369.html 转载请保留说明!

上一篇:MySQL中的唯一索引的简单学习教程(mysql唯一键和唯一索引)

下一篇:Windows下MySQL日志基本的查看以及导入导出用法教程(mysql日志文件在哪里)

  • 仓储服务费税率2021
  • 购入房产计入什么科目
  • 股东购买自己公司产品
  • 企业购买产品
  • 增值税16点税降到13点,补缴税款怎么算
  • 退货折价的账务处理分录
  • 企业所得税前可以扣除的项目
  • 什么情况下纳税调减
  • 年底暂估成本有风险吗
  • 实收资本变更股东要交税吗
  • 专项资金可以存定期吗
  • 产品成本科目包括
  • 西安职业中等专业学校校长
  • 手撕发票流程
  • 怎么查询财务章备案信息
  • 员工离职补偿金可以税前扣除吗
  • 企业 停业
  • 技术开发免征增值税属于普通零税率项目么?
  • 所得税退税会计分录为啥要借贷所得税费用
  • win10教育版用户账户控制怎么取消
  • word从一台电脑考到另一台电脑格式不一致怎么解决
  • 原材料暂估分录
  • 公司清理固定资产怎么开票
  • php生成1到100的数组
  • 如何修复面部毛孔粗大
  • 自产货物用于销售
  • 行政事业单位预算由收入预算、支出预算组成
  • 电商新公司值得去吗
  • 增值税防伪税控系统
  • 交易性金融资产公允价值变动计入
  • 其他收益年末需要结转吗
  • uniapp image mode
  • 信用减值损失在借方是增加还是减少
  • yii框架连接数据库
  • php登录注册整套源码
  • php curl file_get_contents
  • Cursor!!!GPT-4帮我写代码
  • RuntimeError: CUDA error: CUBLAS_STATUS_NOT_INITIALIZED when calling `cublas‘
  • dpkg-configure-a
  • 员工体检费计入福利费吗
  • 资产计税基础填资产原值吗
  • 不得开具增值税专用发票是什么意思
  • 经销商会议是什么意思
  • 出口报关单运费可以填0吗
  • sql server 性能优化
  • 留抵进项税太多怎么办
  • 固定资产账务处理候文江视频
  • 以前年度未结转
  • 跨月的凭证出错如何处理
  • 本期销项税额怎么算
  • 公司多交的社保费法律规定需要退还吗
  • 城建税和教育附加税怎么算
  • 事业单位无形资产包括
  • 企业投资股权收益如何征税
  • 进口关税,增值税是进口设备重置成本中的从属费用
  • 电子增值税发票样本
  • 内账收入如何确认
  • 核销报验登记流程
  • 连锁药店成本会计
  • 以销定产会计怎么做账科目
  • 通过SQL Server的位运算功能巧妙解决多选查询方法
  • centosgui
  • Linux/Mac MySQL忘记密码怎么办
  • 免费获取windows8.1
  • win10无法新建文件夹怎么办?(已解决)
  • 微软补丁发布时间
  • javascript Function函数理解与实战
  • unity 插件开发
  • Python实现mysql数据库更新表数据接口的功能
  • js时间计算相减
  • Node.js中的什么模块是用于处理文件和目录的
  • select类中下拉框选择常见的方法
  • js最简单的代码
  • Unity MeshBaker 合并网格和材质
  • javascript数组的本质
  • pythen开发环境
  • javascript基于什么的语言
  • 核定征收的适用税率
  • 运输服务费税率9%还是6%
  • 中通快递深圳同城多少钱
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设