加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – Spring IllegalStateException:JTA EntityManager不能

发布时间:2020-12-15 04:21:06 所属栏目:Java 来源:网络整理
导读:因此,在一个重大的重构项目之后,我留下了这个例外,并且不确定如何纠正它.它处理的是一些我没写过的代码,我不熟悉它是如何工作的.还有其他问题处理这个例外,但似乎没有一个适合我的情况. 使用EntityManager的类是SpecialClaimsCaseRepositoryImpl: package c
因此,在一个重大的重构项目之后,我留下了这个例外,并且不确定如何纠正它.它处理的是一些我没写过的代码,我不熟悉它是如何工作的.还有其他问题处理这个例外,但似乎没有一个适合我的情况.

使用EntityManager的类是SpecialClaimsCaseRepositoryImpl:

package com.redacted.sch.repository.jpa;

//Imports

@Repository
public class SpecialClaimsCaseRepositoryImpl extends SimpleJpaRepository<SpecialClaimsCaseDto,SpecialClaimsCaseDto.Id> implements SpecialClaimsCaseRepository{

    @PersistenceContext(unitName = "schManager")
    private EntityManager em;

          //Some autogenerated methods

    public void setEntityManager(EntityManager em) {
        this.em = em;
    }

    public EntityManager getEntityManager() {
        return em;
    }
}

persistence.xml中:

<persistence xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
    version="1.0">

    <persistence-unit name="schManager">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <jta-data-source>jdbc/SCH_DS</jta-data-source>
        <class>com.redacted.sch.domain.model.SpecialClaimsCaseDto</class>
        <properties>
            <property name="hibernate.transaction.manager_lookup_class" value="org.hibernate.transaction.WebSphereExtendedJTATransactionLookup" />
            <property name="hibernate.cache.region.factory_class" value="net.sf.ehcache.hibernate.SingletonEhCacheRegionFactory" />
            <property name="hibernate.cache.use_query_cache" value="true" />
            <property name="hibernate.cache.use_second_level_cache" value="true" />
            <property name="hibernate.dialect" value="com.bcbsks.hibernate.dialect.DB2Dialect" />
            <property name="hibernate.format_sql" value="true" />
            <property name="hibernate.generate_statistics" value="false" />
            <property name="hibernate.jdbc.use_scrollable_resultset" value="true" />
        </properties>
    </persistence-unit>
</persistence>

sch_model_spring.xml:

<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:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

        <context:component-scan base-package="com.redacted.repository.jpa,com.redacted.sch.domain.model,com.redacted.sch.repository.jpa,com.redacted.sch.service,com.redacted.sch.service.impl"/>

        <tx:annotation-driven />

        <tx:jta-transaction-manager />

        <!-- Data source used for testing -->
        <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
            <property name="driverClassName" value="com.ibm.db2.jcc.DB2Driver" />
            <property name="url" value="jdbc:db2:redacted.redacted.com" />
            <property name="username" value="redacted" />
            <property name="password" value="redacted" />
        </bean>

        <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
              <property name="persistenceUnitName" value="schManager" />
              <property name="dataSource" ref="dataSource" />
        </bean>

        <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
            <property name="entityManagerFactory" ref="entityManagerFactory" />
        </bean> 
</beans>

这是我的项目结构:

>

这是堆栈跟踪的一部分,在此fpaste处有完整的跟踪

Caused by: java.lang.IllegalStateException: A JTA EntityManager cannot use getTransaction()
    at org.hibernate.ejb.AbstractEntityManagerImpl.getTransaction(AbstractEntityManagerImpl.java:985)
    at org.springframework.orm.jpa.DefaultJpaDialect.beginTransaction(DefaultJpaDialect.java:67)
    at org.springframework.orm.jpa.JpaTransactionManager.doBegin(JpaTransactionManager.java:380)
    ... 80 more

我在这里总是菜鸟,所以如果需要任何其他信息,请问我会更新.

感谢您的帮助!

解决方法

问题是你的配置.您已为JTA配置了休眠.

<property name="hibernate.transaction.manager_lookup_class" value="org.hibernate.transaction.WebSphereExtendedJTATransactionLookup" />

而您使用本地事务而不是分布式事务.

at org.springframework.orm.jpa.JpaTransactionManager.doBegin(JpaTransactionManager.java:380)

您有2种可能的解决方案

>删除JpaTransactionManager并将其替换为JTA事务管理器
>从hibernate设置中删除hibernate.transaction.manager_lookup_class.

如果你真的不需要分布式事务,那么选项2是最简单的,如果你需要分布式事务,只需添加< tx:jta-transaction-manager />将为您的环境设置适当的JTA tx管理器.删除JpaTransactionManager的定义.

更新:

您的配置有两种方式存在缺陷.

>您的EntityManager配置已包含数据源的jndi查找,您可以通过配置本地数据源在applicationContext中覆盖该查找
>你有一个< tx:jta-transaction-manager />和JpaTransactionManager你想使用哪一个?目前后者正在压倒第一个.

创建2个单独的配置,一个用于本地测试,另一个用于生产,使用JTA和JNDI查找. (优选您的测试代码仅覆盖必要的bean).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读