Spring AOP配置死活不起作用,求救

Harryfin 2014-01-07 10:15:50
无论怎么试都无法回滚

AOP配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">

<!-- AOP事务 -->
<tx:advice id="DomainTxAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="delete*" propagation="REQUIRED"/>
<tx:method name="remove*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
<tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="create*" propagation="REQUIRED"/>
<tx:method name="insert*" propagation="REQUIRED"/>
<tx:method name="add*" propagation="REQUIRED"/>
<tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
<tx:method name="load*" propagation="SUPPORTS" read-only="true"/>
<tx:method name="query*" propagation="SUPPORTS" read-only="true"/>
<tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
<tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
</tx:attributes>
</tx:advice>

<aop:config proxy-target-class="true">
<aop:pointcut id="DomainServices" expression="execution(* rsj.frdc.domain..service..*.*(..))"/>
<aop:advisor pointcut-ref="DomainServices" advice-ref="DomainTxAdvice"/>
</aop:config>
</beans>


希望匹配的其中一个方法:
rsj.frdc.domain.datacleaner.schedule.fixplan.service.impl.DirtyRecordFixPlanService.save

方法中人为抛出一个异常:

public void save(DirtyRecordFixRule rule) {
dirtyRecordFixRuleDAO.insert(rule);
throw new RuntimeException("出错了!!!");
}


结果“dirtyRecordFixRuleDAO.insert(rule);”所插入的数据还是进数据库了,没有成功回滚。
...全文
1908 21 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
21 条回复
切换为时间正序
请发表友善的回复…
发表回复
牧心之 2016-08-06
  • 打赏
  • 举报
回复
可能是应为spring-mvc扫描了@service注解导致的http://blog.csdn.net/mmm333zzz/article/details/16858209
gys13200 2014-01-17
  • 打赏
  • 举报
回复
打印一下 service是否代理成功了
Harryfin 2014-01-16
  • 打赏
  • 举报
回复
引用 19 楼 byg760 的回复:
你的

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
</bean>
 
<bean id="oracleDataSource" class="oracle.jdbc.pool.OracleDataSource">

<property name="dataSource" ref="dataSource"/> 不应该是 oracleDataSource 吗????
实际是“ref="${dataSource}"”,然后properties里面配置为oracleDataSource 请大家不要再较真数据源的问题,问题压根就不在数据源这里!
Harryfin 2014-01-15
  • 打赏
  • 举报
回复
引用 14 楼 niit_java 的回复:
有些表的表类型是不支持事务回滚的 确定其他没什么问题 在考虑下这个问题
我直接在service里面人为throw new RuntimeException都不行
礼拜一 2014-01-15
  • 打赏
  • 举报
回复
execution(* rsj.frdc.domain.*.service.*.*(..))试试
paker_ma 2014-01-13
  • 打赏
  • 举报
回复
有些表的表类型是不支持事务回滚的 确定其他没什么问题 在考虑下这个问题
ay转身遇 2014-01-13
  • 打赏
  • 举报
回复
<aop:pointcut id="DomainServices" expression="execution(*rsj.frdc.domain..service.impl..*.*(..))"/> 这个样子试试
雕虫大计 2014-01-13
  • 打赏
  • 举报
回复
需要在调用这个方法的地方捕获抛出的异常
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
引用 7 楼 suciver 的回复:
我怎么在配置文件里没看到楼主的事务管理器 你这个transactionManager的事务管理器没配置啊
我没有全部贴出来

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
	<property name="dataSource" ref="dataSource"/>
</bean>

<bean id="oracleDataSource" class="oracle.jdbc.pool.OracleDataSource">
	<property name="URL" value="${jdbc.url}"/>
	<property name="user" value="${jdbc.username}"/>
	<property name="password" value="${jdbc.password}"/>
	<property name="connectionCachingEnabled" value="true"/>
	<property name="fastConnectionFailoverEnabled" value="false"/>
	<property name="connectionCacheProperties">
		<props>
			<prop key="InitialLimit">${jdbc.pool.initSize}</prop>
			<prop key="MaxLimit">${jdbc.pool.maxSize}</prop>
			<prop key="MinLimit">${jdbc.pool.oracle.MinLimit}</prop>
			<prop key="InactivityTimeout">${jdbc.pool.oracle.InactivityTimeout}</prop>
		</props>
	</property>
	<property name="connectionProperties">
		<props>
			<prop key="v$session.program">${SYSPROP_PROGRAM}</prop>
			<prop key="v$session.terminal">${SYSPROP_TERMINAL}</prop>
		</props>
	</property>
</bean>
suciver 2014-01-07
  • 打赏
  • 举报
回复
我怎么在配置文件里没看到楼主的事务管理器 你这个transactionManager的事务管理器没配置啊
赵增光 2014-01-07
  • 打赏
  • 举报
回复
抛一个checked exception ,例如就抛个 new Exception("")
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
引用 4 楼 love819178 的回复:
加上 rollback-for="Exception"
无论写rollback-for="Exception"还是rollback-for="java.lang.Exception"都一样
love819178 2014-01-07
  • 打赏
  • 举报
回复
加上 rollback-for="Exception"
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
引用 2 楼 love819178 的回复:
用的什么数据库,支持事务吗
用的是Oracle 10g,spring + ibatis的整合方式
love819178 2014-01-07
  • 打赏
  • 举报
回复
用的什么数据库,支持事务吗
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
补充: 无论是否强制使用CGLIB,结果都一样。但是服务器启动时,有显示这个事务的配置文件已被加载。
jackson_fighting 2014-01-07
  • 打赏
  • 举报
回复
引用 11 楼 Harryfin 的回复:
[quote=引用 9 楼 SDN_SUPERUSER 的回复:] 配置没看出来什么问题 "execution(* rsj.frdc.domain..service..*.*(..))" 这个和你包结构是对应的吗?
我已经列出来了,我觉得是对应的,你可以检查下: “希望匹配的其中一个方法:rsj.frdc.domain.datacleaner.schedule.fixplan.service.impl.DirtyRecordFixPlanService.save”[/quote] 你写一个完成的类路径试一下
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
顺便问问有没办法可以判断接口是否已经被代理?代理成功的话,运行时控制台是否有调试信息的呢?
Harryfin 2014-01-07
  • 打赏
  • 举报
回复
引用 9 楼 SDN_SUPERUSER 的回复:
配置没看出来什么问题 "execution(* rsj.frdc.domain..service..*.*(..))" 这个和你包结构是对应的吗?
我已经列出来了,我觉得是对应的,你可以检查下: “希望匹配的其中一个方法:rsj.frdc.domain.datacleaner.schedule.fixplan.service.impl.DirtyRecordFixPlanService.save”
sunbo624 2014-01-07
  • 打赏
  • 举报
回复
换个数据源试试 要么就是你方法的包名类名和你定义的不匹配
加载更多回复(1)

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧