带你理解 只读事务(@Transactional(readOnly = true)

简介: 带你理解 只读事务(@Transactional(readOnly = true)

概念:从这一点设置的时间点开始(时间点a)到这个事务结束的过程中,其他事务所提交的数据,该事务将看不见!(查询中不会出现别人在时间点a之后提交的数据)

应用场合:

如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持SQL执行期间的读一致性;

如果你一次执行多条查询语句,例如统计查询,报表查询,在这种场景下,多条查询SQL必须保证整体的读一致性,否则,在前条SQL查询之后,后条SQL查询之前,数据被其他用户改变,则该次整体的统计查询将会出现读数据不一致的状态,此时,应该启用事务支持。

【注意是一次执行多次查询来统计某些信息,这时为了保证数据整体的一致性,要用只读事务】

在将事务设置成只读后,相当于将数据库设置成只读数据库,此时若要进行写的操作,会出现错误

在方法上添加注解

@Transactional(readOnly = true)

相关文章
|
3月前
|
XML Java 关系型数据库
@Transactional注解的失效场景
@Transactional注解的失效场景
81 1
|
3月前
|
Java 编译器 Spring
@transactional注解失效情况
@transactional注解失效情况
|
3月前
|
Java 数据库 Spring
@Transactional 失效场景介绍
【2月更文挑战第5天】
238 1
@Transactional 失效场景介绍
|
Java 数据库 Spring
@Transactional 注解失效问题
@Transactional 注解失效问题
|
存储 Oracle 安全
|
Java 数据库 Spring
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
|
Java Spring
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
455 0
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
需要在Transactional注解指定rollbackFor或者在方法中显示的rollback
由Java阿里巴巴规范提示得,今日探究其原因 1. 先看异常的分类 error是一定会回滚的 这里Exception是异常,他又分为运行时异常RuntimeException和非运行时异常 可查的异常(checked exceptions):Exception下除了RuntimeException外的异常 不可查的异常(unchecked exceptions):RuntimeException及其子类和错误(Error) 如果不对运行时异常进行处理,那么出现运行时异常之后,要么是线程中止,要么是主程序终止。
3594 0
|
Java 测试技术 数据库
事务注解 @Transactional 失效的3种场景及解决办法
Transactional注解标注方法修饰符为非public时,@Transactional注解将会不起作用。例如以下代码。
事务注解 @Transactional 失效的3种场景及解决办法
|
Java 数据库 Spring
为什么private方法加了@Transactional,事务也没有生效?(上)
为什么private方法加了@Transactional,事务也没有生效?
272 0
为什么private方法加了@Transactional,事务也没有生效?(上)