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

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

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

应用场合:

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

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

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

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

在方法上添加注解

@Transactional(readOnly = true)

相关文章
|
6月前
|
XML Java 关系型数据库
@Transactional注解的失效场景
@Transactional注解的失效场景
106 1
|
1月前
|
Java 测试技术 数据库
@Transactional(readOnly=true):真的是提高性能的灵丹妙药吗?
【10月更文挑战第1天】在Java开发中,特别是使用Spring框架进行企业级应用开发时,@Transactional注解是处理事务管理的一个关键工具。其中,readOnly=true属性常被用来标记一个事务为只读,以期达到提高性能的效果。然而,这一属性是否真的是提高性能的灵丹妙药呢?本文将深入探讨@Transactional(readOnly=true)的工作机制、潜在影响以及在实际应用中的正确使用方法。
50 1
|
6月前
|
Java 编译器 Spring
@transactional注解失效情况
@transactional注解失效情况
|
6月前
|
Java 数据库 Spring
@Transactional 失效场景介绍
【2月更文挑战第5天】
605 1
@Transactional 失效场景介绍
|
Java 数据库 Spring
@Transactional 注解失效问题
@Transactional 注解失效问题
104 0
|
Java 数据库 Spring
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
@Transactional 注解rollbackFor 范围问题以及同一个类方法之间调用事务问题
|
存储 Oracle 安全
需要在Transactional注解指定rollbackFor或者在方法中显示的rollback
由Java阿里巴巴规范提示得,今日探究其原因 1. 先看异常的分类 error是一定会回滚的 这里Exception是异常,他又分为运行时异常RuntimeException和非运行时异常 可查的异常(checked exceptions):Exception下除了RuntimeException外的异常 不可查的异常(unchecked exceptions):RuntimeException及其子类和错误(Error) 如果不对运行时异常进行处理,那么出现运行时异常之后,要么是线程中止,要么是主程序终止。
3618 0
|
Java Spring
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
500 0
Springboot 跟着我了解下 事务 @Transactional 默认方式 Propagation.REQUIRED
|
Java 测试技术 数据库
事务注解 @Transactional 失效的3种场景及解决办法
Transactional注解标注方法修饰符为非public时,@Transactional注解将会不起作用。例如以下代码。
事务注解 @Transactional 失效的3种场景及解决办法