mysql 的ACID以及隔离级别

Wesley13
• 阅读 649

事务:保证数据一致性的重要手段

事务百度上说: 事务(Transaction),一般是指要做的或所做的事情。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。

事务操作是一个阶段操作,是一个过程,而非一个节点

start transaction标识事务开始,commit提交事务,将执行结果写入到数据库。如果sql语句执行出现问题,会调用rollback,回滚所有已经执行成功的sql语句。当然,也可以在事务中直接使用rollback语句进行回滚。

autocommit参数是针对连接的,在一个连接中修改了参数,不会对其他连接产生影响。

也就是说,你cmd 后 输入mysql -uroot -pxxxx 后登录的每一个黑窗口属于一个人连接。

ACID特性

  • 原子性(Atomicity,或称不可分割性)
  • 一致性(Consistency)
  • 隔离性(Isolation)
  • 持久性(Durability)

Oracle默认的事务隔离级别为READ COMMITTED(读已提交) RC,    mysql 默认隔离级别是RR Repeatable Read (可重复读)

mysql 的redo log 

脏读,不可重复读,幻读

脏读: 当前事务(A)中可以读到其他事务(B)未提交的数据(脏数据) , 这种现象是脏读。

create table bank_money (id int auto_increment primary key,name varchar(16),money int); 

insert into bank_money (id,name,money) values (null,"liuyuanyuan",200);

mysql 的ACID以及隔离级别

初始我银行卡账户里面有200块钱

第二个窗口操作如下

mysql 的ACID以及隔离级别

mysql 的ACID以及隔离级别

在第一个窗口查看

mysql 的ACID以及隔离级别

有问题啊,因为二窗口我还未提交,就已经读取到了二窗口未提交的数据,如果这个时候二窗口rollback了呢,回到了200 

mysql 的ACID以及隔离级别

在rollback 或者commit 之前会读取到未提交的数据,rollback 或者commit 后,就会保持一致。

mysql 的ACID以及隔离级别

以上是读未提交的数据

幻读( READ COMMIT):一个事务读取到另一个事务提交的数据(主要表现为某行数据修改--即事务A在操作前先对数据进行读取,事务B对某行数据进行修改,事务A再次读取数据发现数据已不一致)

mysql 的ACID以及隔离级别

上面的查是第一次查,初始查

然后对二窗口进行更改

mysql 的ACID以及隔离级别

然后对窗口一再进行插入同样的数据发现插入不进去,报1062,已经有这个数据了,但是我查询的时候,却查不到,要知道,窗口二我确实commit提交了,这就是幻读。

mysql 的ACID以及隔离级别

如上是幻读的sql 效果展示

幻读,比如我插入id 未2的数据,我先查了一遍,没有啊,张三捷足先登,先插入id 为2的数据,并commit 了,这时候我继续插入,发现不对啊,我没查如果,我刚查的啊,这就是幻读,像产生了幻觉一样,神奇 。

我commit 后,再查一下,发现有人提交了,原来如此,我之前插入不进去 。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
OMG!Java高级开发岗必问知识点
目录1.Mysql2.CHAR与VARCHAR的区别?3.能说下myisam和innodb的区别吗?4.你能说下事务的基本特性和隔离级别吗?5.并发问题脏读、不可重复读、幻读?6.事务的隔离级别?7.说说自增主键、UUID?8.mysql的约束分类?9.drop、delete与tru
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
MySQL数据库InnoDB存储引擎Log漫游(1)
作者:宋利兵来源:MySQL代码研究(mysqlcode)0、导读本文介绍了InnoDB引擎如何利用UndoLog和RedoLog来保证事务的原子性、持久性原理,以及InnoDB引擎实现UndoLog和RedoLog的基本思路。00–UndoLogUndoLog是为了实现事务的原子性,
Wesley13 Wesley13
3年前
Mysql系列第十五讲 事务详解
Mysql系列第十五讲什么是事务?事务的几个特性(ACID)Mysql中事务操作savepoint关键字只读事务事务中的一些问题事务的隔离级别关于隔离级别的选择什么是事务?数据库中的事务是指对数据库执行一批操作,这些操作最终要么
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这