博客
关于我
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/

你可能感兴趣的文章
pl/sql锁
查看>>
PL2303 Windows 10 驱动项目常见问题解决方案
查看>>
QueryPerformanceCounter与QueryPerformanceFrequency
查看>>
Plaid.com的监控系统如何实现与9600多家金融机构的集成
查看>>
Plain Stock Prediction:基于RNN的股票价格预测工具
查看>>
platform_driver与file_operations两种方法开发led驱动
查看>>
PlatON共识方案详解:应用CBFT共识协议,提高共识效率
查看>>
QueryDict和模型表知识补充
查看>>
Querybase 使用与安装教程
查看>>
Playwright与Selenium的对比:谁是更适合你的自动化测试工具?
查看>>
quarz设置定时器任务的有效时间段_定时器?你知道有几种实现方式吗?
查看>>
PLC、DCS、SCADA的选型
查看>>
PLC中的电子凸轮的简单介绍
查看>>
PLC发展详解-ChatGPT4o作答+匹尔西
查看>>
PLC探针有什么用
查看>>
PLC接线详解
查看>>
PLC数组的使用(西门子)
查看>>
Quarzt定时调度任务
查看>>
SpringBoot之AOP详解
查看>>
PLC结构体(西门子)
查看>>