深入解析MySQL 事务

目录
  • 事务的四大特性 ( acid )
    • 脏读
    • 不可重复读
    • 幻读
  • mysql的隔离级别

    事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败。

    事务的四大特性 ( acid )

    原子性(atomicity):一个事物是一个不可分割的单位,要么全都执行,要么都不执行;

    一致性(consistency):事务执行前后,数据处于合法的状态;

    持久性(isolation):事务执行完后,数据的修改是持久的,不会因为其他操作或故障而对其产生影响;

    隔离性(durability):多个事务并发执行的,事务之间不互相干扰。

    假如事物的一个操作整体(动作a,b),动作a,执行完了,动作b,执行到一半,执行过程出错,这时怎么办?有回滚机制,有个日志会记录这些操作,记录数据修改前和数据修改后的值。

    脏读

    事务a正在修改数据(但是没有提交),事务b就读取了这里的数据,此时事务b读取的操作称为脏读。 解决办法:给写操作加锁,当事务a在写数据的时候,事务b无法读取。

    不可重复读

    事务a修改数据之后提交了数据“name=l”,然后事务b就读取数据,但是此时a觉得修改的数据不满意“name=h”,继续修改提交了,此时事务b再次读取,发现,啊,怎么数据不一样了。这就是不可重复读的问题。 解决办法:给写操作加锁的同时,给读操作也加锁,当事务a在写的时候,事务b不可以读,事物b在读的时候,事物a也不可以写。

    幻读

    虽然已经给写操作加锁,和读操作加锁,但是会有种情况,事务b在读的时候,事务a无法修改name,但是事务a可以再写一个age,当事务b再次读取数据的时候发现,咦,怎么多了条数据。 解决办法:只能严格的串行化执行。(并发程度最低,效率也最低,但是数据的可靠性最高)

    这里很容易搞混不可重复读和幻读。其实只需要理解,不可重复读是修改数据,数据的条数不变;幻读是增加或者删除数据,数据的内容不变,条数发生改变。

    mysql的隔离级别

    读未提交(read-uncommitted):会有脏读,不可重复读,幻读问题 不可重复读(read-committed):会有不可重复读,幻读问题 可重复读(repeatable-read):会有幻读问题 串行化 (serializable):解决这三个问题

    事务的隔离级别并不是越高越好,但事务的隔离级别越高,那么并发性就越低,效率越低,数据的可靠性就会越高。

    mysql8开始,用select@@global.transaction_isolation,@@transaction_isolation;查询隔离级别(这里是是mysql5)

    这里我们可以看到mysql的全局隔离级别和当前会话隔离级别皆是repeatable一read(可重复读),不同的数据库有不同的默认隔离级别,而且我们也可以自行修改它。

    通过如下命令可以修改隔离级别(建议在修改时修改当前 session 隔离级别即可,不用修改全局的隔离级别):

    set session transaction isolation level read uncommitted
    

    注意,如果只是修改了当前 session 的隔离级别,则换一个 session 之后,隔离级别又会恢复到默认的隔离级别,所以我们测试时,修改当前 session 的隔离级别即可。

    到此这篇关于深入解析mysql 事务的文章就介绍到这了,更多相关mysql 事务内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

    (0)
    上一篇 2022年3月21日
    下一篇 2022年3月21日

    相关推荐