一个工作了6年的粉丝,去阿里面试,在第一面的时候被问到”Mysql的事务隔离级别“。
他竟然没有回答上来,一直在私信向我诉苦。
我说,你只能怪年轻时候的你,那个时候不够努力导致现在的你技术水平不够。
好吧,关于这个问题,看看普通人和高手的回答。
普通人:
Mysql的事务隔离级别它有四种
1.读已提交
2.可重复读
3.串行化
4.未提交读
这四种隔离级别代表的是说我在不同的那个...就是我多个事务竞争的时候那么我每一个就是我的这个事务并发执行的时候并行执行的时候我对数据的一个影响。
比如说我事务之间的一个隔离性,所以通过不同的这种隔离级别它可以去解决所谓的这个幻读或者不可重复读以及说那个读未提交这些问题。
然后我记得就是这个最安全的是那种就串行化,串行化就是说它不会存在任何的这个上面幻读不可重复读的一些问题。
高手:
好的,关于这个问题,我会从几个方面来回答。
首先,事务隔离级别,是为了解决多个并行事务竞争导致的数据安全问题的一种规范。
具体来说,多个事务竞争可能会产生三种不同的现象。
-
假设有两个事务T1/T2同时在执行,T1事务有可能会读取到T2事务未提交的数据,但是未提交的事务T2可能会回滚,也就导致了T1事务读取到最终不一定存在的数据产生脏读的现象。
-
假设有两个事务T1/T2同时执行,事务