为什么要有事务?

当需要对一个数据表进行一系列多个操作的情况下,为了防止这些操作中一部分操作成功,而另一部分操作失败,从而导致数据不正确,我们就需要事务来控制了。

当两个人或者多个人同时操作同一条数据的时候,会有数据的不统一或者造成幻觉现象,我们就需要事务来控制了。

什么是事务

事务是逻辑上的一组操作,要么都执行,要么都不执行。

假如张三给李四转账100块,这就等价于张三余额减少100,李四的余额增加100.假如系统在张三减少100元之后崩溃了,导致张三余额减少而李四没有增加,那很明显就出问题了。

所以这里就需要 「 事务控制 」 。事务就是保证你这一系列操作要么都成功,要么都失败。

事务的特性(ACID)

原子性: 事务是最小的单位,不允许分割。事务的原子性确保动作要么全部完成,要么全部失败。

一致性: 执行事务前后,数据保持一致。例如转账业务中,无论事务成功与否,转账人和收款人的总金额是不变的。

隔离性: 并发访问数据库时,一个用户的事务不被其它事务所干扰。各并发事务之间数据库是独立的。

持久性: 一个事务被提交之后,它对数据库的改变是持久的,即使数据库发生故障也不应该对其有任何影响。

并发事务带来的问题

数据库并发经常会出现以下几个问题,也是数据库事务面试经常会问到的重点:

脏读(Dirty Read): 指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。因为这个数据是还没有提交的数据,那么另外一个事务读到的这个数据是脏数据,依据脏数据所做的操作可能是不正确的。

事务T1将某一值修改,然后事务T2读取该值,此后T1因为某种原因撤销对该值的修改,这就导致了T2所读取到的数据是无效的。

不可重复读(Unrepeatable Read): 在一个事务内,多次读同一个数据。在这个事务还没有结束时,另一个事务也访问该同一数据并修改数据。那么,在第一个事务的两次读数据之间。由于另一个事务的修改,那么第一个事务两次读到的数据可能不一样,这样就发生了在一个事务内两次读到的数据是不一样的,因此称为不可重复读,即原始读取不可重复。

事务T1读取某一数据,事务T2读取并修改了该数据,T1为了对读取值进行检验而再次读取该数据,便得到了不同的结果

幻读(Phantom read): 当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,比如这种修改涉及到表中的“全部数据行”。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入“一行新数据”。那么,以后就会发生操作第一个事务的用户发现表中还存在没有修改的数据行,就好像发生了幻觉一样。

事务A读取与搜索条件相匹配的若干行。事务B以插入或删除行等方式来修改事务A的结果集,然后再提交。

不可重复读和幻读

不可重复读的重点是修改,幻读的重点在于新增或删除。

例子 (同样的查询条件,你读取过一次,再次读取出来看到数据不一致) : 事务a中张三查看自己的工资是3000元,还未提交事务,事务b中老板给张三发了3000元工资,导致张三还未提交,查询第二次的时候发现工资变成了6000;这就是不可重复读。

例子 (同样的条件,读取出来的数据数量不一致): 假设有个商品库,事务a读取了所有的可口可乐牌的饮料,统一修改价格为5元,这时候事务b新增了一条可口可乐牌的饮料,价格为2.5元。事务a再次读取时查看记录多了一条2.5元的可口可乐饮料(刚刚明明把所有可口可乐相关的都改成了5元的),这样就导致了幻读。

事务的隔离级别

SQL标准定义了四个隔离级别:

读未提交: 最低的隔离级别,允许读取尚未提交的数据变更,

「 该级别可能会导致脏读、幻读或不可重复读 」 。

读已提交: 允许读取并发事务已经提交的数据,

「 可以阻止脏读,但是幻读和不可重复读仍会发生 」 。

可重复读: 对同一字段的多次读取结果是一致的,除非数据是本身事务自己所修改,

「 可以阻止脏读和不可重复读,但是幻读仍有可能发生 」 。

可串行化: 最高隔离级别,完全服从ACID的隔离级别。所有事务依次执行,这样事务之间相互不可能存在干扰,即

「 防止了脏读、不可重复读和幻读 」 。

隔离级别

脏读

不可重复读

幻读

读未提交

true

true

true

读已提交

false

true

true

可重复读

false

false

true

可串行化

false

false

false

MySQL InnoDB存储引擎的默认支持的隔离级别是 REPEATABLE-READ(可重复读) 。可以通过 SELECT @@tx_isolation;命令查看。(MySQL:5.7)

mysql> SELECT @@tx_isolation;+-----------------+| @@tx_isolation |+-----------------+| REPEATABLE-READ |+-----------------+

这里需要注意的是:与 SQL 标准不同的地方在于InnoDB 存储引擎在  REPEATABLE-READ(可重读) 事务隔离级别下使用的是 Next-Key Lock  锁算法,因此可以避免幻读的产生,这与其他数据库系统(如 SQL Server)是不同的。所以说InnoDB 存储引擎的默认支持的隔离级别是 REPEATABLE-READ(可重读) 已经可以完全保证事务的隔离性要求,即达到了 SQL标准的 SERIALIZABLE(可串行化) 隔离级别。

因为隔离级别越低,事务请求的锁越少,所以大部分数据库系统的隔离级别都是 READ-COMMITTED(读已提交) 。但是你要知道的是InnoDB存储引擎默认使用 REPEATABLE-READ(可重读) 并不会有任何性能损失。

InnoDB 存储引擎在 分布式事务 的情况下一般会用到 SERIALIZABLE(可串行化) 隔离级别。

都结合网上资料加上自己的一些理解,如果有影响到他人的地方,可以联系我:fzfz2007@163.com

mysql事务隔离级别 花_MySQL事务的隔离级别相关推荐

  1. mysql事务隔离级别 花_mysql事务隔离级别

    很多PHP开发者在面试的时候遇到这个问题都会卡壳.这是因为理解得不够透彻,今天让我带领大家梳理一下mysql事务隔离级别 数据库有四种隔离级别,分别是Read uncommitted,Read com ...

  2. mysql与spring隔离级别不同_mysql事务隔离级别与spring事务隔离级别的区别

    mysql事务隔离级别与spring事务隔离级别的区别: 脏读:为什么会出现脏读,因为你对数据库的任何修改都会是立即生效的,至于别人能不能看到主要取决与你 是否加锁了,数据库的执行与事务没有关系,事务 ...

  3. mysql事务未提交读_mysql事务之未提交读Read uncommitted(仅学习)

    1,Read uncommitted定义: wiki上的定义如下: 未提交读(READ UNCOMMITTED)是最低的隔离级别.允许脏读(dirty reads),事务可以看到其他事务"尚 ...

  4. mysql行级锁作用_Mysql事务及行级锁的理解

    在最近的开发中,碰到一个需求签到,每个用户每天只能签到一次,那么怎么去判断某个用户当天是否签到呢?因为当属表设计的时候,每个用户签到一次,即向表中插入一条记录,根据记录的数量和时间来判断用户当天是否签 ...

  5. mysql的回滚机制_mysql事务回滚机制概述

    应用场景: 银行取钱,从ATM机取钱,分为以下几个步骤 1 登陆ATM机,输入密码: 2 连接数据库,验证密码: 3 验证成功,获得用户信息,比如存款余额等: 4 用户输入需要取款的金额,按下确认键: ...

  6. mysql 读未提交数据_mysql事务之未提交读(Read uncommitted)

    1,Read uncommitted定义: wiki上的定义如下: 未提交读(READ UNCOMMITTED)是最低的隔离级别.允许脏读(dirty reads),事务可以看到其他事务"尚 ...

  7. mysql 事务 回滚 原理_mysql 事务的实现原理

    一. 开篇 相信大家都用过事务以及了解他的特点,如原子性(Atomicity),一致性(Consistency),隔离型(Isolation)以及持久性(Durability)等.今天想跟大家一起研究 ...

  8. mysql事务是什么意思_mysql事务是什么意思

    mysql事务是一组原子性的SQL查询,或者说一个独立的工作单元,事务内的语句,要么全部执行成功,要么全部执行失败:事务需要符合"原子性"."一致性".&quo ...

  9. mysql如何进行视图恢复_mysql事务 视图 索引 备份和恢复

    事务 1.事务: 概念:是作为单个逻辑工作单元执行的一系列操作 多个操作作为一个整体向系统提交,要么都执行,要么都不执行 事务是一个不可分割的工作逻辑单元 默认情况下 , 每条单独的SQL语句视为一个 ...

最新文章

  1. python sizeof函数_C++ sizeof 运算符 | 菜鸟教程
  2. apiCloud中图片裁剪模块FNImageClip的使用
  3. PMP读书笔记(第9章)
  4. 【Java】Java SimpleDateFormat 线程安全 问题
  5. qt web混合编程_VS2017+QT 混合编程-在VS控制台程序配置QT
  6. 汇编debug与masm命令
  7. Vue中使用pdf.js通过流的方式传参给pdfviewer.html
  8. cocos2dx fnt字体制作
  9. python合并两个文本文件内容_Python将多个txt文本合并为一个文本的代码
  10. 08cms中error_08cms_licens 故障
  11. Fallback class must implement the interface annotated by @FeignClient
  12. Java使用SPARQL访问DBPedia Endpoint错误
  13. OSChina 周二乱弹 —— 春节假期已经完全结束
  14. geany的安装与使用
  15. 【django接口自动化1】环境搭建
  16. C语言实现设置桌面壁纸
  17. Gitlab两个项目代码合并
  18. AdaBoost 算法解析
  19. (R)机器学习--学习笔记--第四章节学习笔记
  20. 批量出售QQ群idcnd传媒提供

热门文章

  1. CentOS 阿里云硬盘扩容
  2. Ubunt_配置_start
  3. JavaScript 中的事件设计
  4. HTML与CSS基础知识补遗(一)
  5. UA MATH567 高维统计 专题0 为什么需要高维统计理论?——协方差估计的高维效应与Marcenko-Pastur规则
  6. UA MATH563 概率论的数学基础 中心极限定理16 Kolmogorov 3-series定理
  7. windows下mysql安装配置启动
  8. 学习旧岛小程序 (5) 自定义组件的自定义事件
  9. 使用Dockerfile制作镜像
  10. Scrapy五大核心组件简介