【问题标题】:Hibernate dialect issue with Spring configurationSpring配置的Hibernate方言问题
【发布时间】:2012-05-13 12:04:32
【问题描述】:

我使用 Spring 配置的 Hibernate(通过 JPA),当我启动我的应用程序(部署在 Tomcat 6 上的战争)时,我收到此错误:

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 Dialect,这一次成功了。这是我如何精确的:

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

你知道为什么不使用 Spring 配置设置 Hibernate Dialect 吗?

【问题讨论】:

  • 如何构建会话工厂?
  • 我只是在 entityManager 引用上使用@PersistenceContext 注释

标签: java mysql spring hibernate jpa


【解决方案1】:

不确定为什么它不适用于您的配置。使用 p: 注释可能会出现问题。我将发布我的代码(适用于我的配置)以尝试它是否会修复您的代码! :)

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="showSql" value="false"/>
            <property name="generateDdl" value="true"/>
            <property name="databasePlatform" value="org.hibernate.dialect.MySQL5Dialect"/>
        </bean>
    </property>
</bean>

祝你好运!

【讨论】:

    【解决方案2】:

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

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

    来自org.springframework.orm.jpa.vendor.HibernateJPAVendorAdapter的相关代码

    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;
        }
    }
    

    【讨论】:

    • 你告诉了我如何更改为自定义 MysqlDialect。只需扩展HibernateJPAVendorAdapter 并覆盖determineDatabaseDialectClass。在MSQL 返回一些自定义dialect 类。希望这可以以这种方式工作
    • am.. 刚刚测试了我的最后一条评论。它运行。但似乎 custom class 从其他覆盖传递给 determineDatabaseDialectClass 什么都不做。事实上,“构造函数”永远不会被调用......
    【解决方案3】:

    可以从DataSource 驱动程序自动检测方言。所以不需要hibernate.dialect 不需要database。 如果发生异常'hibernate.dialect' not set,通常意味着数据库连接有问题:

    <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>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-06-14
      • 2015-01-13
      • 1970-01-01
      • 1970-01-01
      • 2011-05-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多