mysql的事物隔离级别和hibernate是一样的,分为四种, 提交读、未提交读、可重复读、可串行化四种:
READ_UNCOMMITTED(未提交读)
事物中的修改,即使咩有提交,其他事物也是可见的,称之为未提交读的隔离级别,当A事物修改一条数据的时候,B事物读取这个数据,非常不安全,这也称为脏读。
READ_COMMITTED(提交读)
这个是最常见的、使用最多的一种隔离级别,一个事物开始的时候只能看见已经提交的事物所做的修改,一个事物从开始直到提交之前,事物中的修改对其他事物不可见。
REPEATABLE_READ(可重复读)
这个级别解决了脏读的问题,该级别保证同一份事物中多次读取的的结果是一致的。但会产生幻读的问题,指的是在某个事物在读取某个范围内的记录的时候,另外一个事物在这个范围插入新的记录,再读取这个范围数据的时候会产生幻行。
SERIALIZABLE(串行化)
是最高的隔离级别,强制事物串行执行,性能低下,很少用。