为什么要有隔离级别?
当数据库有多个事务同时执行的时候,就可能出现脏读、不可重复读、幻读的问题,为了解决这些问题,就有了隔离级别
脏读:事务a修改了数据,但是a事务还未提交,此时事务b读取到了事务a修改的操作。
不可重复读:事务A在事务B提交前读取到的结果和事务B提交后的结果不一致。
幻读:select查询a不存在,执行insert操作,发现a已存在,无法插入。
mysql的个隔离级别包括:读未提交、读提交、可重复读、串行化
读未提交:一个事务还未提交,它做的变更别的事务就能读取到,存在脏读、不可重复读、幻读的问题
读提交:一个事务提交之后,它做的变更才会被其他事务看到。解决脏读的问题,存在不可重复读、幻读的问题
可重复读:一个事务执行过程中看到的数据总是跟这个事务在开启时看到的数据是一致的(在本次事务执行过程中,读取到的数据 是不会改变的,无论另一个事务是否提交)。mysql 默认级别,解决脏读、不可重复读的问题,存在幻读的问题。使用MMVC机制 实现可重复读
串行化:读写操作都会加锁,读写冲突时,后访问的事务必须要等前一个事务执行完毕方可执行。解决脏读、不可重复读、幻读,可保证事务安全,但完全串行执行,性能最低
事务隔离的实现
每条记录在更新的时候都会同时记录一条回滚操作。同一条记录在系统中会存在多个版本,这就是数据库的多版本并发控制(MVCC)。
回滚日志什么时候删除?
系统会判断当没有事务需要用到这些回滚日志的时候,回滚日志会被删除。
什么时候不需要了?
当系统里没有比这个回滚日志更早的read-view的时候。