mysql 事务

事务 ACID 特性

  • 原子性Atomicity): 事务中的所有操作,要么全部成功,要么全部失败回滚到最初状态,不会结束在中间的某个环节
  • 一致性Consistency): 事务开始之前和结束之后,数据库的完整性没有被破坏,写入的数据必须完全符合所有的预设约束,触发器,级联回滚等等
  • 隔离性Isolation): 数据库并发事务同时对其数据进行读写和修改,隔离性可以防止并发事务交叉执行而导致数据不一致
  • 持久性Durability): 事务处理结束后,对数据的修改是永久的,即使系统故障也不会丢失

事务的并发问题

  • 脏读: 一个事务读取另一个事务未更新的数据
  • 不可重复读: 一个事务读取同一个行数据两次得到不同的结果
  • 幻读: 两次范围查询,第二次查询出现第一次更多或者更少的数据
  • 丢失更新1: 两个事务同时更新一行数据,其中一个事务撤销时覆盖另一个事务
  • 丢失更新2: 两个事务同时更新一行数据,其中一个事务提交时覆盖另一个事务

事务的隔离级别

  • 读未提交(Read uncommitted): 允许脏读/不可重复读/幻读/丢失更新2;修改数据时加行级共享锁至事务结束
  • 读已提交(Read committed): 允许不可重复读/幻读/丢失更新2,一个事务只能读取另一个事务已提交的数据;修改数据时加行级排它锁至事务结束
  • 可重复读(Repeatable read): 允许幻读;读取数据时加行级共享锁至事务结束,修改数据时加行级排它锁至事物结束
  • 串行化(Serializable): 串行化所有操作;读取数据加表级共享锁,修改数据时加表级排它锁
隔离级别 脏读 不可重复读 幻读 丢失更新1 丢失更新2
读未提交
读已提交
可重复读
串行化

隔离级别越高,越能保证数据库的完整性和一致性,但性能也越差,mysql innodb 引擎默认使用的是可重复读级

链接

转载请注明出处
本文链接:https://tech.hatlonely.com/article/61

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 事务处理 事务处理是数据库中的一个大块头,涉及到数据的完整性与一致性问题,由于mysql存在多种数据存储引擎提供给...
    tanghomvee阅读 4,114评论 0 0
  • 一、事务概述 我们可以将事务理解为一组sql语句的集合。事务可以只包含一条sql,也可以包含多条sql,事务中所有...
    国球乒乓阅读 2,994评论 0 0
  • https://www.runoob.com/mysql/mysql-transaction.html[https...
    王王王王王景阅读 21,272评论 4 23
  • 事务的定义 事务由单独单元的一个或多个SQL语句组成,在这个单元中,每个MySQL语句是相互依赖的。而整个单独单元...
    诸葛坚强阅读 4,801评论 0 3
  • 我不是标题党,绝对不会故弄玄虚,是的,我说的就是货真价实的骗子。在生活里骗钱的人,经济学里搞庞氏骗局的人。 也许你...
    大卫会武术阅读 11,619评论 0 5

友情链接更多精彩内容