sofast 2020-06-03
spring在TransactionDefinition接口中定义了七个事务传播行为:
事务隔离级别 | 脏读 | 不可重复读 | 幻读 |
读未提交(Read-Uncommitted) | 是 | 是 | 是 |
读已提交(Read-Committed) | 否 | 是 | 是 |
可重复读(Repeatable-Read) | 否 | 否 | 是 |
串行化(Serializable) | 否 | 否 | 否 |
mysql默认的事务隔离级别为Repeatable-Read, Innodb引擎支持事务,MyIsam引擎不支持事务。mysql实现可重复读的方式为第一次读取数据后保存一个快照,以后直接读快照,所以也叫快照读。
orcale默认的事务隔离级别为Read-Committed
事务的并发问题
1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据
2、不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。
3、幻读:系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。
脏读会产生错误数据,是不可允许的,不可重复读与幻读是在多次读取中数据发生了变化,数据是有效的。
不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表