~~~~~~~~~~
oracle支持事务隔离级别:
三大问题:
幻想读:读取到其它已提交事务添加的数据。
不可重复读:读取到其它已提交事务修改的数据。
脏读:读取到其它未提交事务添加修改的数据。
oracle支持隔离级别:
READ COMMITTED:支持幻想读及不可重复读,不支持脏读
SERIALIZABLE:三大问题都不支持
oracle默认READ COMMITTED,SQL标准默认级别为SERIALIZABLE
oracle设置隔离级别:
SET TRANSACTION ISOLATION LEVEL [SERIALIZABLE|READ COMMITTED]
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
spring支持事务类型:
MANDATORY:强制事务,如果当前没有事务,则抛出异常。
REQUIRED:支持当前事务,如果没有事务则新建一个事务。
REQUIRED_NEW:新建事务,如果当前事务存在,则挂起当前事务。
SUPORTS:支持当前事务,如果当前没有事务,则以非事务方式执行。
NOT_SUPPORTED:以非事务方式执行,如果当前存在事务,则把当前事务挂起。
NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。
NESTED:如果当前事务不存在,则等同于REQUIRED,否则执行方法前保存一个savepoint,如果方法执行成功,则与当前事务同时提交,如果失败则回滚到执行前保存的savepoint,并继续后续处理,与影响主事务。
与REQUIRED_NEW部分类似即内层事务不影响外部事务,不同的是NESTED内层事务不是独立事务,依赖与外部事务,如果内部执行成功则在外部事务提交的时候同时提交。
spring事务隔离级别:
Serializable:最严格的级别,事务串行执行,资源消耗最大。
REPEATABLE READ:保证了一个事务不会修改另外一个事务读取但未提交的数据,避免了“脏读取”和“不可重复读取“的情况,但是带来了更多的性能损失。
READ COMMITTED:保证事务不会读取到另外一个并行事务已经修改但未提交的数据,避免了“脏读取”。
Read Uncommitted:保证读去过程中不会读取到非法数据。
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
oracle锁类型: