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

你可能感兴趣的文章
Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
查看>>
Netty源码—2.Reactor线程模型一
查看>>
Netty源码—4.客户端接入流程一
查看>>
Netty源码—4.客户端接入流程二
查看>>
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—6.ByteBuf原理二
查看>>
Netty源码—7.ByteBuf原理三
查看>>
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>