博客
关于我
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源码—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
查看>>
NFS共享文件系统搭建
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx Location配置总结
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>
nginx 后端获取真实ip
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>