UnsupportedOperationException:应用程序必须提供JDBC连接JPA Hibernate Spring JDBC

时间:2017-02-14 04:54:08

标签: java spring hibernate jpa jdbc

当我尝试开始交易时

entityManager.getTransaction().begin();

在AbstractDao中,我得到了

java.lang.UnsupportedOperationException: The application must supply JDBC connections

我的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="pu" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
        <property name="hibernate.hbm2ddl.auto" value = "create-drop"/>
    </properties>
</persistence-unit>
</persistence>

我的hibernate.properties

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ewp?createIfNotExist=true
jdbc.username=root
jdbc.password=root
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.show_sql=true
hibernate.format_sql=false
hibernate.hbm2ddl.auto=create-drop

EntityManagerFactory bean:

    @Bean
public EntityManagerFactory entityManagerFactory(){
    EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("pu");
    return entityManagerFactory;
}

EntityManager bean:

@Bean
public EntityManager entityManager(){
    return entityManagerFactory.createEntityManager();
}

2 个答案:

答案 0 :(得分:1)

从休眠site,您的属性名称看起来不正确。它应该是,

"hibernate.connection.driver_class" for JDBC driver class
"hibernate.connection.url" for JDBC URL
"hibernate.connection.username" for database user
"hibernate.connection.password" for database user password

更正您的媒体资源名称。

答案 1 :(得分:0)

如果您使用spring orm使用休眠模板,则需要提供如下配置。 我们将hibernate-entitymanager用于Hibernate作为JPA实现。 hibernate-entitymanager依赖于hibernate-core这就是为什么我们不必将hibernate-core明确地放在pom.xml中。它通过maven传递依赖进入我们的项目。

在spring.xml中

<beans xmlns=.....>
<context:component-scan base-package="com.town.practice" />
<context:annotation-config />
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="org.hsqldb.jdbcDriver" />
        <property name="url" value="jdbc:hsqldb:mem://productDb" />
        <property name="username" value="sa" />
        <property name="password" value="" />
    </bean>

    <bean id="entityManagerFactory" 
            class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
            p:packagesToScan="com.town.practice.model"
            p:dataSource-ref="dataSource"
            >
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                <property name="generateDdl" value="true" />
                <property name="showSql" value="true" />
            </bean>
        </property>
    </bean>

    <!-- Transactions -->
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory" />
    </bean>
    <!-- enable the configuration of transactional behavior based on annotations -->
    <tx:annotation-driven transaction-manager="transactionManager" />

</beans>