【问题标题】:Hibernate not creating table when using Spring DAO使用 Spring DAO 时休眠不创建表
【发布时间】:2010-08-31 21:24:33
【问题描述】:

我正在尝试将 Spring DAO 与 Hibernate 一起用于 Web 应用程序。当我尝试使用

在 DAO 中保留信息时
getHibernateTemplate().save("bar", bar);

我在 Tomcat 中得到以下信息:

org.springframework.dao.InvalidDataAccessResourceUsageException: could not insert: 
[com.enw.foo.domain.Bar]; nested exception is org.hibernate.exception.SQLGrammarException: could not insert: [com.enw.foo.domain.Bar]

日志文件报告:

SEVERE: Servlet.service() for servlet foo threw exception
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'foo.bar' doesn't exist
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39

这并不奇怪,我预计该表不存在。数据库确实存在,我指望 Hibernate 根据需要生成和更改表。

休眠映射文件包含:

<class name="Bar" table="BAR">
  <id name="id" column="BAR_ID">
  <generator class="native"/>
    </id>
  <property name="title" column="TITLE"/>
  <property name="date" type="timestamp" column="POST_DATE"/>
</class>

而spring配置主要发生在foo-data.xml里面包含:

<bean id="barDao" class="com.enw.foo.data.impl.HibernatePostDao">
    <property name="sessionFactory" ref="sessionFactory"/>
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="mappingResources">
        <list>
            <value>Domain.hbm.xml</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
            <prop key="show_sql">true</prop>
            <prop key="hbm2ddl.auto">update</prop>
        </props>
    </property>
</bean>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
           <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/foo"/>
    <property name="username" value="root"/>
    <property name="password" value=""/>
    <property name="initialSize" value="5"/>
    <property name="maxActive" value="10"/>
</bean>

【问题讨论】:

  • 您确定该表存在吗?你能告诉我们执行的 SQL 吗?
  • 表不存在,我希望 Hibernate 创建它。
  • 问题是否特定于“Bar”实体?是否创建了其他表?如果是,“BAR”表的真实名称是什么?
  • 嗯,目前这是唯一的桌子,因为我只是想把所有东西都连接起来。但是,更改名称不会改变结果。

标签: java mysql hibernate spring dao


【解决方案1】:

试试这个:

<prop key="hibernate.hbm2ddl.auto">update</prop>

【讨论】:

  • 非常感谢!你能告诉我你是怎么想出来的吗?是否有关于可以设置的各种属性的文档?
  • @Farmboy 好吧,我有一个使用上述属性的项目,它正在工作并且它具有前缀:) 关于各种属性,Hibernate 文档将是正确的地方。请参阅Chapter 3. Configuration
猜你喜欢
  • 2018-01-14
  • 2023-03-16
  • 1970-01-01
  • 2011-11-11
  • 1970-01-01
  • 1970-01-01
  • 2012-09-14
  • 2012-04-01
相关资源
最近更新 更多