首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL的事务隔离级别

本文信息架构

1. 事务的原则介绍

2. 事务并发会造成的问题

3. MySQL的事务隔离级别

事务的原则

1、原子性:在事务中的操作,必须同时完成或者同时回滚,不会只成功或者回滚一部分。

2、一致性:不能破坏数据库的一致性状态。

3、隔离性:不同的事务之前互相不能影响。

4、持久性:事务完成以后,即保存数据,不会再回滚。

事务并发造成的问题

1、脏读

事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据。

比如:

B把小明的年龄更新成12岁,但是事务还未提交。此时A来读小明的年龄,读到了12岁,然后去做自己的处理。之后B把小明的年龄回滚到11岁。这个例子中A读到的12岁就是脏数据。

2、不可重复读

事务A多次读取同一数据,事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果不一致。

比如:

B先把小明的余额更新为100元,A来读的时候读到的是100元,然后B又把余额更新为90元,此时A来读的时候读到的就是90元,也就是A读到的数据前后不一致。

3、幻读

事务A对表中的数据进行了修改,涉及到表中的全部行。同时,事务B也修改这个表中的数据,向表中插入一行新数据。那么,事务A发现表中还有自己没有修改的行,就好象发生了幻觉一样。

比如:

A先把所有人的余额清零,同时,B往表中插入了一条余额为100的数据。A提交以后,发现竟然还有100的,命名刚刚都更新成0了呀。

MySQL的事务隔离级别

1、读未提交:能读到未提交的数据。

2、读已提交:读已提交的数据。

3、可重复读:mysql默认,查询的都是事务开始时的数据。

4、串行读:完全串行化读,每次都会锁表,读写互相阻塞。

—END—

自由,

是因为自己真的有方向。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20181011G1MW7100?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券