0

Spring 3.2 と Hibernate 4.2 を適切に構成する方法を理解するのに苦労しています。過去数日間にわたっていくつかの問題に取り組んだ後、DAO でクエリを実行しようとしたときに、次の例外に遭遇しました。

java.lang.UnsupportedOperationException: The application must supply JDBC connections
org.hibernate.service.jdbc.connections.internal.UserSuppliedConnectionProviderImpl.getConnection(UserSuppliedConnectionProviderImpl.java:62)
org.hibernate.internal.AbstractSessionImpl$NonContextualJdbcConnectionAccess.obtainConnection(AbstractSessionImpl.java:292)
org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:214)
org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.getConnection(LogicalConnectionImpl.java:157)
org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.doBegin(JdbcTransaction.java:67)
org.hibernate.engine.transaction.spi.AbstractTransactionImpl.begin(AbstractTransactionImpl.java:160)
org.hibernate.internal.SessionImpl.beginTransaction(SessionImpl.java:1426)
org.hibernate.ejb.TransactionImpl.begin(TransactionImpl.java:59)
com.bsj.demo.rest.dao.DemoUserDaoImpl.getAllDemoUsers(DemoUserDaoImpl.java:41)

ここに私のSpringとHibernateのファイルがあります:

context.xml

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

<context:property-placeholder location="classpath:spring/data-access.properties"/>

<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/restdemo"/>
</bean>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
    </property>
    <property name="persistenceUnitManager">
        <bean class="org.springframework.orm.jpa.persistenceunit.DefaultPersistenceUnitManager">
             <property name="defaultDataSource" ref="dataSource" />
        </bean>
    </property>
    <property name="dataSource" ref="dataSource" />
</bean>

<context:component-scan base-package="com.bsj.demo.rest.*">
    <context:include-filter type="annotation"  expression="org.springframework.stereotype.Repository" />
</context:component-scan>

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

<context:spring-configured />
<context:annotation-config />
<bean class="com.bsj.demo.rest.spring.config.AppConfig"/>
</beans>

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_2_0.xsd"
version="2.0">
<persistence-unit name="RESTDemoJPA" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>
    </properties>
</persistence-unit>

私は何が欠けていますか?私の理解では、Spring がデータソースと永続化ユニットを定義しているため、persistence.xml で必要な構成はほとんどないはずです。ここで私は完全に間違っていますか?

サーバーは Tomcat 7 で、依存関係は Maven によって管理されます。これは SO に関するよくある質問であることは理解していますが、いくつかの解決策を試した後、この問題を解決する方法が見つかりませんでした。

4

2 に答える 2

1

わかりました、私は問題を把握しましたが、それは実際には構成とは関係ありませんでした。問題は、コードで EntityManager をインスタンス化する方法でした。

構成では、entityManager Bean 定義に以下を追加する必要がありました。

<property name="persistenceUnitName" value="RESTDemoJPA" />

より大きな問題は、EntityManagerFactory からインスタンスを取得して、各 DAO で EntityManager を作成していたことです。代わりに、Spring が PersistenceContext アノテーションを介して次のように注入できるようにする必要がありました。

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

それを行った後、へのすべての呼び出しを削除しem.getTransaction()、クラスに注釈を付け、@Transactional例外はなくなりました。その後、データベースにクエリを実行できました。

TL;DR: entityManager 定義で Persistence Unit 名を定義していない構成は正しかった。EntityManager のインスタンス化を手動から Spring インジェクションに変更しました。

于 2013-05-31T20:03:07.977 に答える