mysql默认事务隔离级别是什么?

sql的4种事务隔离级别,如下所示:

1、读取未提交(Read Uncommitted):最低的隔离级别,也就是可能读取到其他会话中未提交事务修改的数据,可能导致脏读幻读不可重复读

2、读取已提交(Read Committed):只能读取到已经提交的数据(并发事务已提交的数据),可以阻止脏读,但是幻读或不可重复读仍有可能发生。Oracle等多数数据库默认都是该级别 (不重复读)。

3、可重复读(Repeated Read):在同一个事务内的查询都是事务开始时刻一致的,InnoDB默认级别。在SQL标准中,该隔离级别消除了不可重复读,但是还存在幻读,但是innoDB解决了幻读。(对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改)

4、可串行化(Serializable):最高的隔离级别,所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说该级别可以防止脏读、不可重复读以及幻读。完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞。

你可能感兴趣的:(mysql,数据库)