美文网首页程序员MySQL高性能MySQL
MySQL实战 | 03 - 谁动了我的数据:浅析MySQL的事

MySQL实战 | 03 - 谁动了我的数据:浅析MySQL的事

作者: hoxis | 来源:发表于2018-12-10 13:10 被阅读50次

    原文链接:这一次,带你搞清楚MySQL的事务隔离级别!

    使用过关系型数据库的,应该都事务的概念有所了解,知道事务有 ACID 四个基本属性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),今天我们主要来理解一下事务的隔离性。

    声明:MySQL专栏学习系列,基本上是本人学习极客时间《MySQL实战45讲》专栏内容的笔记,并在专栏基础上进行知识点挖掘。侵删。
    本人也不是什么 DBA,所以有些错误的地方请大家指正,相互交流,共同进步!

    什么是事务?

    数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。—— 维基百科

    事务的概念看上去不难,但是需要注意以下几个点:

    1、首先,事务就是要保证一组数据库操作,要么全部成功,要么全部失败;

    2、在 MySQL 中,事务支持是在引擎层实现的;

    3、并不是所有引擎都支持事务,如 MyISAM 就不支持,InnoDB 就支持;


    今天,我们的主角是隔离性,隔离性是指当多个用户并发操作数据库时,数据库为每一个用户开启不同的事务,这些事务之间相互不干扰,相互隔离。

    为什么需要隔离性?

    如果事务之间不是互相隔离的,可能将会出现以下问题。

    1、脏读

    脏读(dirty read),简单来说,就是一个事务在处理过程中读取了另外一个事务未提交的数据。

    这种未提交的数据我们称之为脏数据。依据脏数据所做的操作肯能是不正确的。

    还记得上节中我们提到的 dirty page 吗?这种临时处理的未提交的,都是「脏」的。

    举例

    时间点 事务A 事务B
    1 开启事务A
    2 开启事务B
    3 查询余额为100
    4 余额增加至150
    5 查询余额为150

    比如,你给小编赞赏 1 分钱,整个事务需要两个步骤:
    ①给小编账号加一分钱,这时小编看到了,觉得很欣慰;
    ②你的账号减一分钱;

    但是,若该事务未提交成功,最终所有操作都会回滚,小编看到的一分钱也只是镜花水月。

    你的关注是对我最大的鼓励!

    最近搜集到传智播客 2018 最新 Python 和 Java 教程!关注本公众号,后台回复「2018」即可获取下载地址。

    公众号提供CSDN资源免费下载服务!


    相关文章

      网友评论

      本文标题:MySQL实战 | 03 - 谁动了我的数据:浅析MySQL的事

      本文链接:https://www.haomeiwen.com/subject/hieicqtx.html