Java Spring配置的Hibernate方言问题

Java Spring配置的Hibernate方言问题,java,mysql,spring,hibernate,jpa,Java,Mysql,Spring,Hibernate,Jpa,我使用Spring配置的Hibernate(通过JPA),当我启动我的应用程序(部署在Tomcat 6上的war)时,我得到以下错误: org.hibernate.HibernateException: Connection cannot be null when 'hibernate.dialect' not set 这似乎很奇怪,因为我将hibernate方言设置为: p:databasePlatform="org.hibernate.dialect.MySQL5Dialect 有关详

我使用Spring配置的Hibernate(通过JPA),当我启动我的应用程序(部署在Tomcat 6上的war)时,我得到以下错误:

org.hibernate.HibernateException: Connection cannot be null when 'hibernate.dialect' not set 
这似乎很奇怪,因为我将hibernate方言设置为:

p:databasePlatform="org.hibernate.dialect.MySQL5Dialect
有关详细信息,请参见我的完整applicationContext.xml:

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


    <bean id="dataSource"
          class="org.springframework.jdbc.datasource.DriverManagerDataSource"
          p:driverClassName="com.mysql.jdbc.Driver"
          p:url="jdbc:mysql://localhost/room_management" p:username="root" p:password=""/>

    <bean id="entityManagerFactory"
          class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
          p:dataSource-ref="dataSource" p:persistenceUnitName="RoomManagement">
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"
                  p:database="MYSQL"
                  p:databasePlatform="org.hibernate.dialect.MySQL5Dialect"
                  p:showSql="true"/>
        </property>
    </bean>

    <bean id="transactionManager"
          class="org.springframework.orm.jpa.JpaTransactionManager"
          p:entityManagerFactory-ref="entityManagerFactory"/>

    <context:annotation-config/>


    <context:component-scan base-package="com.parisdescartes.roommanagement.*"/>

    <tx:annotation-driven/>

</beans>

所以,我决定在META-INF/persistence.xml文件中使用Hibernate方言,这次可以了。以下是我对它的评价:

<properties>
            <property name="hibernate.dialect"
                      value="org.hibernate.dialect.MySQL5Dialect"/>
</properties>


您知道为什么Hibernate方言不使用Spring配置设置吗?

不确定为什么它不能与您的配置一起使用。使用p:annotation可能有问题。我将发布我的代码(适用于我的配置),以尝试是否可以修复您的代码!:)



祝你好运

有点晚了,但我认为这会增加价值。不一定需要添加
databasePlatform
属性如果指定
database
属性,适配器本身将识别方言

<property name="database" value="MYSQL" />

可以从
数据源
驱动程序自动检测方言。因此,下面的
hibernate。方言
no
数据库
是必需的。
如果发生异常
“hibernate.dialogue”未设置
,则通常意味着数据库连接出现问题:

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
      p:dataSource-ref="dataSource"
      p:packagesToScan="ru.javawebinar.**.model">

    <property name="jpaPropertyMap">
        <map>
            <entry key="#{T(org.hibernate.cfg.AvailableSettings).FORMAT_SQL}" value="${hibernate.format_sql}"/>
            <entry key="#{T(org.hibernate.cfg.AvailableSettings).USE_SQL_COMMENTS}" value="${hibernate.use_sql_comments}"/>
        </map>
    </property>

    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"
              p:showSql="${jpa.showSql}">
        </bean>
    </property>
</bean>


如何构建会话工厂?我只在entityManager引用上使用@PersistenceContext注释。您告诉我如何更改为自定义
mysqldialent
。只需扩展
hibernatejbavendorapter
并覆盖
determinedatabasedianalclass
。在
MSQL
中,返回一些自定义
方言
类。希望这能以那种方式起作用。。刚刚测试了我最后的评论。它运行。但似乎从其他override
DeterminedatabaseDiagnolClass
传递给的
自定义类什么也不做。事实上,“构造函数”从未被调用过。。。
protected Class determineDatabaseDialectClass(Database database) {
    switch (database) {
        case DB2: return DB2Dialect.class;
        case DERBY: return DerbyDialect.class;
        case H2: return H2Dialect.class;
        case HSQL: return HSQLDialect.class;
        case INFORMIX: return InformixDialect.class;
        case MYSQL: return MySQLDialect.class;
        case ORACLE: return Oracle9iDialect.class;
        case POSTGRESQL: return PostgreSQLDialect.class;
        case SQL_SERVER: return SQLServerDialect.class;
        case SYBASE: return SybaseDialect.class;
        default: return null;
    }
}
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
      p:dataSource-ref="dataSource"
      p:packagesToScan="ru.javawebinar.**.model">

    <property name="jpaPropertyMap">
        <map>
            <entry key="#{T(org.hibernate.cfg.AvailableSettings).FORMAT_SQL}" value="${hibernate.format_sql}"/>
            <entry key="#{T(org.hibernate.cfg.AvailableSettings).USE_SQL_COMMENTS}" value="${hibernate.use_sql_comments}"/>
        </map>
    </property>

    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"
              p:showSql="${jpa.showSql}">
        </bean>
    </property>
</bean>