tx:advice 是 spring xml 中定义事务增强的配置标签,用于封装事务行为并配合 AOP 切面生效,需与 aop:config 或 aop:aspectj-autoproxy 配合使用,仅声明不生效。

tx:advice 是 Spring XML 配置中用于定义事务增强(Transaction Advice)的标签,它本身不开启事务,而是把事务行为(如传播行为、隔离级别、回滚规则等)封装成一个可被 AOP 切面引用的配置块。
为什么需要 tx:advice 而不是直接用 @Transactional
在纯 XML 驱动的老项目、或需要将事务策略与业务代码彻底解耦(比如事务规则由运维配置、或跨多个模块复用同一套事务语义)时,tx:advice 提供了声明式、中心化的事务行为定义能力。它必须配合 aop:config 或 aop:aspectj-autoproxy 使用,否则不会生效。
- 仅声明
tx:advice不会自动代理任何方法 - 它不绑定具体类或方法,只描述“如果被织入,就按这个规则执行事务”
- 无法通过它指定哪些类参与事务——那是
aop:pointcut的职责
tx:advice 的基本结构和关键属性
它必须嵌套在 tx:advice 标签内,并通过 transaction-manager 指定事务管理器(如 transactionManager)。内部用 tx:attributes 定义方法匹配规则与事务属性。
-
name支持通配符(*、?),但不支持正则表达式 -
propagation默认是REQUIred,常见值:REQUIRES_NEW、NEVER、NOT_SUPPORTED -
isolation只对REQUIRED和REQUIRES_NEW有效;设为default表示使用数据库默认隔离级别 -
rollback-for和no-rollback-for接收以英文逗号分隔的异常全限定名,例如java.lang.RuntimeException,com.example.MyBizException
如何让 tx:advice 生效:必须配对 aop:config
没有切面织入,tx:advice 就是静态配置。最常用方式是用 aop:config 关联 pointcut 和 advice:
-
aop:advisor是连接点(pointcut)和增强(advice)的桥梁,不能省略 - 若用了
,则tx:advice会被忽略——两者互斥 - Spring 从 4.2 开始默认不启用 CGLIB 代理,若目标类无接口,需显式设置
proxy-target-class="true"在aop:config或tx:annotation-driven中
常见错误与排查线索
配置完没事务?大概率卡在这几个地方:
- 忘记声明
或——tx:advice自身不触发代理 - pointcut 表达式没匹配到实际方法(比如包路径写错、方法签名含泛型导致匹配失败)
- 事务管理器 bean 名字拼错,或未正确定义(如漏了
) - 方法被同类内其他方法直接调用(非代理对象调用),绕过 AOP 代理——这是 Spring 事务的固有限制,XML 和注解都一样
- 捕获了异常但没重新抛出,导致事务切面感知不到异常,不触发回滚
事务边界模糊、回滚不生效、或读写分离场景下 read-only="true" 没起作用,往往不是 tx:advice 写错了,而是 pointcut 织入位置或事务管理器底层数据源配置出了问题。