问题
脏读:
一个事务读取到另一个事务中未提交的数据,另一个事务中数据可能进行了改变,此时A事务读取的数据可能和数据库中数据时不一致的,此时认为数据是脏数据,读取脏数据的过程就叫做脏读。
不可重复读
1.主要针对的是某行数据
2.主要针对的操作是修改操作
3.两次读取在同一个事务内
当事务A第一次读取事务后,事务B对事务A读取的淑君
进行修改,事务 A 中再次读取的数据和之前读取的数据不一致,过
程不可重复读.
幻读
1.主要针对的操作是新增或删除
2.两次事务的结果.
3.事务A按照特定条件查询出结果,事务B新增了一条符合
条件的数据.事务 A 中查询的数据和数据库中的数据不一致的,事
务 A 好像出现了幻觉,这种情况称为幻读.
解决
DEFAULT: 默认值,由底层数据库自动判断应该使用什么隔离界别
READ_UNCOMMITTED: 可以读取未提交数据,可能出现脏读,不
重复读,幻读.(效率最高)
READ_COMMITTED:只能读取其他事务已提交数据.可以防止脏
读,可能出现不可重复读和幻读.
REPEATABLE_READ: 读取的数据被添加锁,防止其他事务修改
此数据,可以防止不可重复读.脏读,可能出现幻读.
SERIALIZABLE: 排队操作,对整个表添加锁.一个事务在操作数
据时,另一个事务等待事务操作完成后才能操作这个表.(最安全,效率低)