READ UNCOMMITED(读未提交)
即读取到了正在修改但是却还没有提交的数据,这就会造成数据读取的错误。
READ COMMITED(提交读/不可重复读)
它与READ UNCOMMITED的区别在于,它规定读取的时候读到的数据只能是提交后的数据。
这个级别所带来的问题就是不可重复读。即上一个时间读取到的a的值是1,但是随着修改线程对事务的提交,a的值变为了2,这时候读到的值就是2了,即执行两次相同的读取操作得到的值却不一样。
REPEATED READ(可重复读)
它是MySQL数据库的默认隔离级别。简单来说就是在一个事务的执行期间禁止其他事务对相应的数据进行修改,这就彻底使得一个事务的执行过程中所查询到的数据一定是一致的,即解决了脏读和不可重复读的问题,但是却带来了新的问题,即“幻读”。
“幻读”指的是在一个事务执行过程中虽然禁止了对相应数据的修改,但是其他的事务依然可以插入数据,这时候第一个事务就会发现会“莫名其妙”多出来一些数据,像是出现了幻觉似的。幻读和不可重复读都是读取了另一条已经提交的事务(这点同脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。
SERIALIZABLE (可串行化)
这是最严格的一个隔离级别。它通过强制事务串行执行,避免了幻读的问题。
参考链接