Mysql的隔离级别

为什么要有隔离级别?

当数据库有多个事务同时执行的时候,就可能出现脏读、不可重复读、幻读的问题,为了解决这些问题,就有了隔离级别

脏读:事务a修改了数据,但是a事务还未提交,此时事务b读取到了事务a修改的操作。

不可重复读:事务A在事务B提交前读取到的结果和事务B提交后的结果不一致。

幻读:select查询a不存在,执行insert操作,发现a已存在,无法插入。

mysql的个隔离级别包括:读未提交、读提交、可重复读、串行化

读未提交:一个事务还未提交,它做的变更别的事务就能读取到,存在脏读、不可重复读、幻读的问题

读提交:一个事务提交之后,它做的变更才会被其他事务看到。解决脏读的问题,存在不可重复读、幻读的问题

可重复读:一个事务执行过程中看到的数据总是跟这个事务在开启时看到的数据是一致的(在本次事务执行过程中,读取到的数据  是不会改变的,无论另一个事务是否提交)。mysql 默认级别,解决脏读、不可重复读的问题,存在幻读的问题。使用MMVC机制 实现可重复读

串行化:读写操作都会加锁,读写冲突时,后访问的事务必须要等前一个事务执行完毕方可执行。解决脏读、不可重复读、幻读,可保证事务安全,但完全串行执行,性能最低

事务隔离的实现

每条记录在更新的时候都会同时记录一条回滚操作。同一条记录在系统中会存在多个版本,这就是数据库的多版本并发控制(MVCC)。

回滚日志什么时候删除?

系统会判断当没有事务需要用到这些回滚日志的时候,回滚日志会被删除。

什么时候不需要了?

当系统里没有比这个回滚日志更早的read-view的时候。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值