MySQL——事务的基本操作

在数据库中,事务是指一组逻辑操作单元,使数据从一种状态变换到另一种状态。

为确保数据库中数据的一致性,事务的操作应该是流畅完成的,中间不能失败,一旦有操作失败,那么回滚到开始事务的状态。
《MySQL——事务的基本操作》

事务的特点(ACID)

  • 原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生
  • 一致性:事务必须使数据库从一个一致性状态变换到另一个一致性状态。(数据不被破坏)
  • 隔离性:一个事务的执行不能被其他事务干扰,一个事务内部的操作及使用的数据对并发的事务也是隔离的。每一个事务都存在一个事务空间,彼此不干扰
  • 持久性:一个事务一旦被提交,它对数据库的改变就是永久性的,接下来的其他操作和数据库故障不应该对其有任何影响

事务控制的语言

  • [ begin ]:开启一个事务,开启一个新的事务空间
  • [ commit ]:提交事务
  • [ rollback ]:回滚事务

《MySQL——事务的基本操作》
每次begin开启一个事务后,选择commit和rollback结束本次事务。要重新begin开启一个新的事务。

事务的并发问题

存在五种问题:脏读、不可重复读、幻读、第一类丢失更新、第二类丢失更新
隔离级别:不同的隔离级别可以处理不同的并发问题
默认的隔离级别为:repreatable read
MySQL默认情况下不会出现幻读和第一类丢失更新
《MySQL——事务的基本操作》

第一类丢失更新(回滚丢失)

《MySQL——事务的基本操作》

第二类丢失更新(覆盖丢失)

《MySQL——事务的基本操作》

不可重复读

《MySQL——事务的基本操作》

幻读

《MySQL——事务的基本操作》

脏读

《MySQL——事务的基本操作》
MySQL使用锁机制来解决第二类丢失更新
悲观锁:

select ......for update;

乐观锁:使用版本控制

    原文作者:AnthonyYMH
    原文地址: https://segmentfault.com/a/1190000019231392
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞