Java Hibernate不会自动创建表

Java Hibernate不会自动创建表,java,spring,hibernate,Java,Spring,Hibernate,我有一个带有Hibernate和Spring框架的Maven项目。 我希望Hibernate自动创建表,但是所有现有的表都会被删除,而所需的表不会被创建。 会话工厂初始化期间不会引发异常,但当我尝试保存Player实体时,会引发异常: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:表“billboardb.player”不存在 如果我手动创建表并将属性hibernate.hbm2ddl.auto更改为“validate”,那么

我有一个带有Hibernate和Spring框架的Maven项目。 我希望Hibernate自动创建表,但是所有现有的表都会被删除,而所需的表不会被创建。 会话工厂初始化期间不会引发异常,但当我尝试保存
Player
实体时,会引发异常:

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:表“billboardb.player”不存在

如果我手动创建表并将属性
hibernate.hbm2ddl.auto
更改为
“validate”
,那么一切都会正常工作。 你知道为什么Hibernate不创建表吗

Spring配置文件:

<context:component-scan  base-package="org.meluk.billboard.business.controller" />
<tx:annotation-driven transaction-manager="txManager" />
<bean id="propertyConfigurer"  class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations" >
        <list>
            <value>/WEB-INF/config/jdbc.properties</value>
        </list>
    </property>
</bean>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="${hibernate.connection.driver_class}" />
    <property name="url" value="${hibernate.connection.url}" />
    <property name="username" value="${hibernate.connection.username}" />
    <property name="password" value="${hibernate.connection.password}" />
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean" >
    <property name="dataSource" ref="dataSource" />
    <property name="configLocation" value="/WEB-INF/hibernate.cfg.xml" />
    <property name="packagesToScan" value="org.meluk.billboard.jpa" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">${hibernate.dialect}</prop>
            <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
            <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
            <prop key="hibernate.c3p0.min_size">${hibernate.c3p0.min_size}</prop>
            <prop key="hibernate.c3p0.max_size">${hibernate.c3p0.max_size}</prop>
            <prop key="hibernate.c3p0.timeout">${hibernate.c3p0.timeout}</prop>
            <prop key="hibernate.c3p0.max_statements">${hibernate.c3p0.max_statements}</prop>
        </props>
    </property>
</bean>

<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>
休眠依赖项:

<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-entitymanager</artifactId>
  <version>${hibernateVersion}</version>
</dependency>
<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-c3p0</artifactId>
  <version>${hibernateVersion}</version>
</dependency>
<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-tools</artifactId>
  <version>${hibernateToolsVersion}</version>
</dependency>

org.hibernate
休眠实体管理器
${hibernateEversion}
org.hibernate
hibernate-c3p0
${hibernateEversion}
org.hibernate
休眠工具
${hibernateToolsVersion}

将以下条目添加到hibernateProperties道具中

<prop key="hibernate.hbm2ddl.auto">create</prop>
创建

我解决了这个问题。Hibernate无法使用mysqlinnodb方言创建表。
现在我改用mysql5innodbdialent。

是的,它们是相似的,但生成的表很好。只是给你一个想法。如果所有配置都正确,请检查数据库的方言设置。我已经检查过很多次了。你是如何定义Entity的,Player?你能把代码片段放进去吗?我定义它:“${hibernate.hbm2ddl.auto}”它抛出“com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException”?映射是否都正确?是否已将show sql设置为true?获取日志中提交的脚本,并直接使用db客户端运行它们。看看它是否有问题。我没有看到任何用于删除或创建表的sql。只有:“INFO:Hibernate:insert-into-Player(年龄、电子邮件、密码)值(?,?)”我之前使用了
mysqldialent
,并将其更改为
mysql5dialent
(添加了“5”)。我也做了这项工作。