2014-03-27 76 views
0

对于我的EJB bean的某种原因,一个间接调用当我运行上面的设置的代码与弹簧@Transactional注解EJB 3和Spring @Transactional

注释一个DAO,我得到一个交易异常像下面

javax.ejb.EJBException: org.springframework.transaction.TransactionSystemException: Could not commit Hibernate transaction; nested exception is org.hibernate.TransactionException: commit failed 
at org.jboss.as.ejb3.tx.CMTTxInterceptor.handleExceptionInOurTx(CMTTxInterceptor.java:166) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:230) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.as.ejb3.tx.CMTTxInterceptor.required(CMTTxInterceptor.java:304) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.as.ejb3.tx.CMTTxInterceptor.processInvocation(CMTTxInterceptor.java:190) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ejb3.component.interceptors.CurrentInvocationContextInterceptor.processInvocation(CurrentInvocationContextInterceptor.java:41) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ejb3.component.interceptors.LoggingInterceptor.processInvocation(LoggingInterceptor.java:59) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ee.component.NamespaceContextInterceptor.processInvocation(NamespaceContextInterceptor.java:50) ~[jboss-as-ee-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ejb3.component.interceptors.AdditionalSetupInterceptor.processInvocation(AdditionalSetupInterceptor.java:43) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ee.component.TCCLInterceptor.processInvocation(TCCLInterceptor.java:45) ~[jboss-as-ee-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.invocation.ChainedInterceptor.processInvocation(ChainedInterceptor.java:61) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ee.component.ViewService$View.invoke(ViewService.java:165) ~[jboss-as-ee-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.as.ee.component.ViewDescription$1.processInvocation(ViewDescription.java:173) ~[jboss-as-ee-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) ~[jboss-invocation-1.1.1.Final.jar!/:1.1.1.Final] 
at org.jboss.as.ejb3.component.interceptors.AsyncFutureInterceptorFactory$1$1.runInvocation(AsyncFutureInterceptorFactory.java:71) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at org.jboss.as.ejb3.component.interceptors.AsyncInvocationTask.run(AsyncInvocationTask.java:73) ~[jboss-as-ejb3-7.1.1.Final.jar!/:7.1.1.Final] 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) ~[na:1.6.0_29] 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) ~[na:1.6.0_29] 
at java.lang.Thread.run(Unknown Source) [na:1.6.0_29] 
at org.jboss.threads.JBossThread.run(JBossThread.java:122) ~[na:na] 

的事务管理我的bean定义看起来像

<bean id="transactionManager" 
    class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
    <property name="sessionFactory"> 
     <ref bean="sessionFactory" /> 
    </property> 
</bean> 

任何人都可以扔的是什么这个问题有一些启发,我应该如何correc它呢?

+0

我不认为你提供了足够的信息。我们可以看到一些正在运行的代码吗?也许在你提供的第一行之上有一点堆栈跟踪? – jervine10

+0

您正在使用EJB,但正在尝试本地事务,我希望您必须使用JTA事务来参与正在进行的事务。 –

回答

0

尝试使用@TransactionAttribute(NOT_SUPPORTED)来标记您的EJB方法。但是,如果你想一起使用Spring和EJB,甚至是使用Hibernate(JPA),你应该只依赖容器服务:允许通过JBOSS引发JPA,从JNDI获得Spring的事务管理器(刚够添加<tx:jta-transaction-manager/>)等。

从其他方面来说,如果你有Spring,为什么你需要EJB?

+0

谢谢阿尔乔姆,我试着用@TransactionAttribute(NOT_SUPPORTED)注释我的dao类,但它似乎不能解决问题。如果我使用,我该如何提供数据源.sessionFactory等。 –

+0

1.如果您使用JPA,为什么需要'sessionFactory'? 2.'DataSource'也必须被JBOSS容器拾取,你可以从JNDI中获得它。 –