首页 > 数据库 >MySQL事务(InnoDB)

MySQL事务(InnoDB)

时间:2022-10-20 19:55:35浏览次数:54  
标签:事务 log 幻读 InnoDB MySQL 数据 隔离

MySQL事务(InnoDB)

事务的概念

事务就是一个不可分割的操作单元,其中的多个操作被认为是一个整体,要么全部执行成功,要么执行失败。

事务的特性

通常来说,我们一般认为事务具有四个特性。

隔离性

不同的事务之间,是互相隔离的,不会互相影响。

通过锁和MVCC来实现。

持久性

一旦事务执行完成,那么对事务中影响到的数据的变化,是永久的,一般是指持久化到磁盘上或者日志文件中。

通过redo log来实现

原子性

一个事务中的多个操作,被认为是一个整体,不可再分割,只要其中一个操作执行失败,就认为整个事务执行失败了。

基于undo log

一致性

事务执行完成后,对于数据的变化,要求要一致。举例来说,转帐,A向B转账,B向C转账,在两个操作结束之后,数据结果要求一致。

通过回滚,以及恢复,和在并发环境下的隔离做到一致性,也就是基于上述的 redo logundo logMVCC等一起实现。

并发事务可能产生的问题

脏读

事务A可以读到事务B未commit的数据

不可重复读

同一事务的其他实例在该实例处理其间可能会有新的commit,同一select可能返回不同结果, 查询结果的值有变化

幻读

用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行, 查询结果行数变化。

事务隔离级别

事务隔离级别是一个标准,在不同的事务隔离级别下,对于事务特性的保证是有差异的,随之也会产生一些问题。

读未提交

不同的事务之间,会读到其他事务未提交的数据。保证了持久性原子性,但是没有保证隔离性及一致性,会出现以下问题:

  • 脏读
  • 幻读
  • 不可重复读

读已提交

不同事务之间,只会读取到其他事务提交的数据,解决了脏读的问题,但依然存在

  • 幻读
  • 不可重复读

可重复读(MySQL默认的隔离级别)

解决了不可重复读的问题,保证了同一事务中多次读取的数据是一样的。会存在

  • 幻读

串行化

不同的事务之间,不再具备并发能力,只能一个个排着队执行,解决了上述的问题,但性能极差。

标签:事务,log,幻读,InnoDB,MySQL,数据,隔离
From: https://www.cnblogs.com/strive-for-life/p/16811050.html

相关文章

  • SQL优化笔记(MySQL)
    SQL优化笔记(MySQL)目标减少IO次数降低CPU的计算基本原则1.尽量少joinMySQL的优势在于简单,但这在某些方面其实也是其劣势。MySQL优化器效率高,但是由于其统......
  • windows10安装MYSQL服务端
    一、下载安装包1.下载地址:点击mysql安装包下载链接:https://dev.mysql.com/downloads/mysql/,选择window版本,点击下载按钮2.解压缩到无中文字符的路径:二、配置环境变量1.......
  • Mysql慢sql优化
    Mysql慢sql优化index1.MySQL的执行过程2.索引的定义3.MySQL执行计划explainordesc4.索引使用/创建规则5.弊端6.设计规范7.SQL建议1.MySQL的执行过程 2.索引的定......
  • Mysql分区
    Mysql从5.1版本开始支持分区的功能,分区是指根据一定的规则,数据库把一个表分解成多个更小的、更容易管理的部分,就访问数据库而言,逻辑上只有一个表或一个索引,但是实际上这个......
  • 对比传统自建数据库,华为云数据库 RDS for MySQL优势明显!
    对于数据库,想必大家都已经不再陌生,但若要解释它是什么,当下市场上的数据库又有着怎样的不同,相信不少小伙伴都处于一知半解的懵逼状态。今天,就让我们来系统的认识一下数据库。......
  • Mysql 系列 | 性能优化 - 紧急临时处理
    在实际开发过程中,业务高峰期常遇到Mysql响应变慢。为了不影响业务,要在短时间内临时提升性能。短链接原因分析短链接是连接数据库后,执行很少的SQL后就断开,下次需......
  • Navicat for MySQL 批量执行多个 SQL 文件---Windows-Type命令
    1.背景描述有个同事给发了一个数据库初始化sql文件夹,里面是有99个.sql文件,而我本地的数据库客户端是NavicatforMySQL,不论是在数据库上右键运行SQL文件还是在查询界面的......
  • HeidiSQL、Navicat、mysql命令和source命令导入sql脚本的速度比较
    一、四种导入方式的比较1、heidisql客户端是一条一条插入的,速度最慢,而且很脆弱比较容易崩溃;2、mysql命令导入380万记录用时1小时13分(属于前台运行的命令,ctrl+c就可以结束......
  • Mysql变量插入中文失败
    当给变量赋值中文时,报错:mysql>createprocedurepro_test4()->begin->declareheightintdefault175;->declaredescriptionvarchar(50)default......
  • CentOs 7 安装mysql(5.7.27)数据库
    CentOs7安装MySQL1.查看是否已经安装Mysql[root@srv01~]# rpm-qa|grepmysql# 如果你查看出来有东西,可以使用下面命令将其删除[root@srv01~]# ......