Mysql数据库的事务隔离机制


一、事务特性(ACID)

原子性: 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用;

一致性: 执行事务前后,数据保持一致,例如转账业务中,无论事务是否成功,转账者和收款人的总额应该是不变的;

隔离性: 并发访问数据库时,一个用户的事务不被其他事务所干扰,各并发事务之间数据库是独立的;

持久性: 一个事务被提交之后。它对数据库中数据的改变是持久的,即使数据库发生故障也不应该对其有任何影响。

二、事务并发带来的问题

  • 脏读:当一个事务正在访问数据并进行了修改,而这种修改还没有提交到数据库,这是另一个事务访问了数据库并读取了这个数据,因为这是个还没有被提交的数据,所以另一个事务读到的数据就是脏数据,依据脏数据所做的操作可能是不正确的。
  • 丢失修改: 一个事务读取数据的时候另一个事物也读取了数据,两个事务都修改了数据,那么第一次提交的事务对数据所做的修改就会被第二次事务的提交覆盖。
  • 不可重复读:指在一个事务中多次读同一个数据的时候,另一个事务对数据进行了修改,那么就造成了第一个事务中两次读取的数据不一样的情况,
  • 幻读:幻读类似于不可重复读,他发生在一个事物(T1)读取了几行数据,接着另一个事务(T2)并发插入了一些数据时,事务T1就发现多了一些不存在的记录,就好像发生了幻觉一样。

不可重复读和幻读的区别:不可重复读重在修改,幻读重在添加和删除

三.不同的事务隔离机制

  • 读取未提交 :最低的隔离级别,允许读取尚未提交的数据,可能会导致脏读幻读不可重复读
  • 读取已提交:允许读取并发事务已提交的数据,可以阻止脏读,但是幻读、不可重复读仍有可能发生
  • 可重复读:对同一字段的多次读取结果是一致的,除非数据被本身的事务修改,可以阻止脏读不可重复读,但还是会出现幻读。
  • **可串行化:**最高的隔离级别,完全服从ACID的隔离级别,所有的事务必须依次逐个执行,这样事物之间就完全不可能产生干扰。可以阻止:脏读,不可重复读,幻读

mysql inNoDB存储引擎默认支持的隔离级别是可重复度
innoDB在分布式事务的情况下一般采用的是可串行化级别。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值