无法通过 JPA 出站网关插入


@Bean
public IntegrationFlow reimInvJpaOutbound() {
    return IntegrationFlows
                    .from("reimInvProcessChannel")
                    .handle(reimJpaHandlers.reimStgInsertJpaHandler())
                    .log()
                    .get(); 
}
@Component
@Transactional
public class ReIMJpaHandlers {
Logger logger = LoggerFactory.getLogger(this.getClass()); 
@PersistenceContext
protected EntityManager entityManager;
@Autowired
ReIMHistInvHdrStgRepository histRepo; 
@Autowired
ReIMInvHdrStgRepository stgRepo; 
@Autowired
ReIMErrInvHdrStgRepository errRepo; 
String responseQueryString = "select * from RMS16DEV.TSC_IM_DOC_HEAD_TEMP where error_ind != null"; 
@Bean
public JpaUpdatingOutboundEndpointSpec reimStgInsertJpaHandler() {
    System.out.println("Writing to reim stg");
    return Jpa
        .updatingGateway(entityManager)
        .entityClass(TSC_IM_DOC_HEAD_TEMP.class)
        ; 
}
@Bean
public JpaPollingChannelAdapter reimStgResponseJpaInboundAdapter() {
    return Jpa
            .inboundAdapter(entityManager)
            .nativeQuery(responseQueryString)
            .maxResults(100)
            .get(); 
}
}

但是我得到以下错误:

javax.persistence.TransactionRequiredException: No EntityManager with actual transaction available for current thread - cannot reliably process 'merge' call
at org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:292) ~[spring-orm-5.1.5.RELEASE.jar:5.1.5.RELEASE]
at com.sun.proxy.$Proxy189.merge(Unknown Source) ~[na:na]

你的

@Component
@Transactional
public class ReIMJpaHandlers {

@Bean
public JpaUpdatingOutboundEndpointSpec reimStgInsertJpaHandler() {

最后一个是 bean,它存在于自己的生命周期中,它的所有方法调用都已经在ReIMJpaHandlers @Transactional之外发生。

您需要考虑为.handle(reimJpaHandlers.reimStgInsertJpaHandler())配置TX管理器:

.handle(reimJpaHandlers.reimStgInsertJpaHandler(), e -> e.transactional())

假设您有一个名称为 transactionManager 的 bean。

类的@Transactional应用于业务方法,但不应用于@Bean创建 bean 时只调用一次的方法。

相关内容

  • 没有找到相关文章

最新更新