博客
关于我
Spring中的事务属性
阅读量:316 次
发布时间:2019-03-01

本文共 827 字,大约阅读时间需要 2 分钟。

1. 事务传播属性

事务传播属性决定了事务在多个资源Manager之间如何传播。常见的属性包括: - **REQUIRED**:如果外部存在事务,当前事务会融入外部事务;如果外部没有事务,会开启新的事务。 - **SUPPORTED**:如果外部存在事务,当前事务会融入外部事务;如果外部没有事务,当前事务不会开启新的事务。 - **REQUIRED_NEW**:每次开启新的事务,如果外部存在事务,当前事务会等待外部事务挂起,等待其完成后继续执行。 - **NOT_SUPPORTED**:如果外部存在事务,会立即挂起当前事务,采用非事务方式执行。 - **NEVER**:完全不支持事务,如果外部存在事务会报错。 - **MANDATORY**:强制要求事务存在,否则会报错。 - **NESTED**:允许嵌套事务,但数据库不支持。

2. 事务的隔离级别

隔离级别决定了事务在读取数据时的行为,主要用于防止并发问题。常见的隔离级别包括: - **DEFAULT**:采用数据库默认的隔离级别。 - **READ_UNCOMMITTED**:允许读未提交的数据,读写不一致的风险较高。 - **READ_COMMITTED**:确保读操作基于已提交的事务,避免脏读现象。 - **REPEATABLE_READ**:允许在同一事务中重复读取数据,避免不可重复读现象。 - **SERIALIZABLE**:确保事务的读操作是序列化的,避免幻影读现象。

3. 读写和异常性

- **ReadOnly**:`true`表示事务只读,`false`表示可以写入数据。 - **RollbackFor**:指定在遇到某些异常时自动回滚的事务。 - **NoRollbackFor**:指定在遇到某些异常时不回滚事务。 - **Timeout**:设置超时时间,-1表示无限超时。

通过合理配置这些属性,可以更好地控制事务的行为,确保系统的健壮性和数据一致性。

转载地址:http://ergo.baihongyu.com/

你可能感兴趣的文章
ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
查看>>
ORA-08102的错误
查看>>
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
查看>>
ORA-12514: TNS:listener does not currently know of service问题原因
查看>>
ora-12541:tns:no listener
查看>>
【docker知识】联合文件系统(unionFS)原理
查看>>
ORACEL学习--理解over()函数
查看>>
ORAchk-数据库健康检查
查看>>
oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
查看>>
Oracle 10g ORA-01034: ORACLE not available 错误
查看>>
oracle 10g的安装配置
查看>>
Oracle 11.2.0.4 x64 RAC修改public/private/vip/scan地址
查看>>
Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析
查看>>
viewpage listview gridview加载本地大图多图OOM处理办法
查看>>
Oracle 11g UNDO表空间备份增强
查看>>
Oracle 11g 使用RMAN备份数据库
查看>>
Oracle 11g 单实例安装文档
查看>>
Oracle 11g 操作ASM权限问题
查看>>
Oracle 11g 数据类型
查看>>
Oracle 11g 编译使用BBED
查看>>