当前位置: 首页
科技数码
@Transactional性能优化:3种适用场景与避坑指南

@Transactional性能优化:3种适用场景与避坑指南

热心网友 时间:2025-12-02
转载

@Transactional 注解作为 Spring 框架中声明式事务管理的核心组件,能够显著简化数据库事务操作。在传统编程式事务开发中,开发人员需要手动编写事务开启、提交和回滚的样板代码,而通过该注解则能实现事务逻辑与业务代码的优雅解耦。

运行环境:SpringBoot3.4.2

1. 核心概念解析

@Transactional 注解是 Spring 实现声明式事务管理的关键机制,其设计初衷在于降低数据库事务操作的复杂度。只需在方法或类级别添加该注解,Spring 便会基于 AOP(面向切面编程)技术自动拦截方法调用,在执行前开启事务,完成后根据异常情况自动提交或回滚。这种设计不仅提高了代码可读性,更增强了系统的可维护性。

但若不当使用该注解,可能会对系统性能产生显著的负面影响,主要体现在以下几个方面:

过度使用会导致事务范围扩大,延长数据库连接占用时间,增加锁竞争和死锁风险。不必要的事务细化会引发频繁的提交和回滚操作,加重数据库负担。在非关键数据操作或纯读场景中滥用事务,会造成系统资源的无谓消耗,从而降低整体吞吐量。

本文将重点探讨基于 JPA 和 JDBC 时,@Transactional 注解对查询性能的具体影响。

纯查询场景下究竟是否需要开启事务?

2. 实战性能测试

2.1 测试环境搭建

配置文件

spring: datasource: driverClassName: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/batch username: root password: 123123 type: com.zaxxer.hikari.HikariDataSource hikari: minimumIdle: 10 maximumPoolSize: 10 jpa: generateDdl: false hibernate: ddlAuto: update openInView: true show-sql: false

实体对象定义

@Entity @Table(name = "o_user") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; private String name; private Integer age; private String phone; private String sex; // 省略getter/setter方法 }

接口配置

@GetMapping("") public ResponseEntity query() { return ResponseEntity.ok(this.userService.queryUser()); }

测试数据准备(500万条)

图片图片

2.2 Repository查询性能对比

测试场景1:无事务注解

private final UserRepository userRepository; public User queryUser() { return this.userRepository.findById(4888888).orElse(null); }

JMeter压力测试结果:

图片图片

平均吞吐量:9700

测试场景2:启用事务注解

@Transactional public User queryUser() {}

JMeter压力测试结果:

图片图片

平均吞吐量:12700

测试场景3:配置只读事务

@Transactional(readOnly = true) public User queryUser() {}

JMeter压力测试结果:

图片图片

平均吞吐量:9300

这个结果与不使用注解时差异不大。

思考:为何使用@Transactional注解后性能反而有所提升?欢迎大家留言探讨。

2.3 JDBC查询性能分析

测试场景1:无事务注解

private final JdbcTemplate jdbcTemplate; public User queryUser() { return this.jdbcTemplate.queryForObject( "select id, name, age, phone, sex from o_user where id = 4888888", new RowMapper() { @Override public User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getInt("id")); user.setAge(rs.getInt("age")); user.setName(rs.getString("name")); user.setPhone(rs.getString("phone")); user.setSex(rs.getString("sex")); return user; } }); }

JMeter测试结果:

图片图片

平均吞吐量:25000

JPA确实简化了开发,但代价就是性能表现较差。

测试场景2:启用事务注解

@Transactional public User queryUser() {}

JMeter测试结果:

图片

平均吞吐量:13100

这个结果符合我们的预期,使用@Transactional注解后性能明显下降。

测试场景3:配置只读事务

@Transactional(readOnly = true) public User queryUser() {}

JMeter测试结果:

图片图片

平均吞吐量:9800

同样符合预期,与读写事务的表现基本相当。

2.4 EntityManager查询测试

测试场景1:无事务注解

private final EntityManager em; public User queryUser() { return this.em.find(User.class, 4888888); }

JMeter测试结果:

图片图片

平均吞吐量:24000

测试场景2:启用事务注解

@Transactional public User queryUser() { return this.em.find(User.class, 4888888); }

JMeter测试结果:

图片图片

平均吞吐量:13000

测试场景3:配置只读事务

@Transactional(readOnly = true) public User queryUser() {}

JMeter测试结果:

图片图片

平均吞吐量:9800

2.5 性能数据可视化

图片图片

2.6 查询场景事务使用总结

保证数据一致性:在事务范围内,所有查询都能看到同一时间点的数据快照(具体取决于隔离级别),有效避免其他事务中途修改导致的数据不一致问题。

性能优化策略:Spring 提供 @Transactional(readOnly = true) 配置,明确标记只读事务。这能让底层数据库(如 Oracle、MySQL InnoDB)进行针对性优化,比如启用只读快照、减少锁竞争等。连接复用优势:同一事务中的多个操作可以复用数据库连接,减少连接创建和释放的开销。与写操作兼容:如果查询方法被包含在更大的写事务中,有 @Transactional 注解可以无缝集成。

如下多个查询使用事务保证了同一时间点的数据:

private final UserRepository userRepository; private final OrderRepository orderRepository; @Transactional(readOnly = true) public UserInfoDto getUserInfo(Long userId) { User user = userRepository.findById(userId); List orders = orderRepository.findByUserId(userId); return new UserInfoDto(user, orders); }


来源:https://www.51cto.com/article/826703.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
比亚迪确认收购欧洲闲置工厂计划属实

比亚迪确认收购欧洲闲置工厂计划属实

一则关于比亚迪加速欧洲本土化布局的最新动态,近日引发了汽车行业广泛关注。据权威财经媒体报道,这家全球领先的中国新能源汽车制造商正在与Stellantis集团等多家欧洲主流汽车制造商进行深入接触,核心议题是商讨接管后者在欧洲地区利用率不足或闲置的工厂设施。 今日,比亚迪官方通过中证金牛座等渠道证实了谈

时间:2026-05-15 18:33
成都机器人吸引爱尔兰议员驻足互动海外嘉宾纷纷点赞

成都机器人吸引爱尔兰议员驻足互动海外嘉宾纷纷点赞

2026年成都国际友城合作与发展大会现场,一股源自本土的“硬核”科技风潮成为全场瞩目的焦点。来自成都的“智元”远征A2机器人、“四川具身”情感交互机器人等前沿产品集中展示,其创新形态与智能交互能力迅速吸引了众多与会嘉宾的关注。 会议期间,爱尔兰统一党议员基兰·丹尼森对这些成都制造的机器人表现出浓厚兴

时间:2026-05-15 18:32
东华测试在可控核聚变结构强度测试中的应用与进展

东华测试在可控核聚变结构强度测试中的应用与进展

可控核聚变,被誉为解决人类未来能源需求的终极方案。然而,从科学构想到工程实现,需要坚实而渐进的技术积累。近期,在一次专业的技术研讨中,东华测试分享了其在核能测试领域的最新动态,为我们洞察这一尖端行业的进展提供了具体视角。 从战略布局分析,公司的技术能力已全面覆盖核能发展的两大主流路径。在面向未来的可

时间:2026-05-15 18:32
美股科技股普遍下跌英伟达连续七日创新高白银价格大跌近5

美股科技股普遍下跌英伟达连续七日创新高白银价格大跌近5

5月14日晚,美股市场开市呈现高开态势,三大股指全线飘红。然而,市场的乐观情绪并未能持续蔓延至所有板块。 大型科技股普遍承压下行。截至当晚22:00左右,芯片巨头英伟达却逆势上扬,涨幅接近3%,股价连续第七个交易日刷新历史纪录,总市值攀升至5 63万亿美元。回顾过去两个月,其累计涨幅已接近24%,势

时间:2026-05-15 18:32
马斯克携幼子访华引热议 孩子穿中式服装学普通话

马斯克携幼子访华引热议 孩子穿中式服装学普通话

5月14日,特斯拉CEO埃隆·马斯克现身北京人民大会堂,其6岁儿子X AE A-XII(昵称小X)的造型成为全场焦点。这位小男孩身着复古中式马甲与虎头帽,手拎精致虎头包,活泼可爱的模样迅速在各大社交平台引发热议,收获无数网友点赞。 当晚,马斯克本人在社交媒体上用中文发文,分享了一个温馨细节:“我的儿

时间:2026-05-15 18:31
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程