【问题标题】:At which point Hibernate Generates Tables?Hibernate 在什么时候生成表?
【发布时间】:2012-03-09 13:42:49
【问题描述】:

我正在查看 spring-data-jpa(实际上是我第一次使用 entityManager) 而且我没有看到任何错误,但 entityManager 似乎没有为实体类Account 生成表。这是我在 maven main/resources/META-INF 文件夹中的应用程序上下文(project-model-config.xml)

 <bean id="propertyConfigurer"
      class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
        <list>
            <value>classpath:mysql.hibernate.properties</value>
            <value>classpath:mysql.jdbc.properties</value>
            <!--<value>classpath:liquibase.properties</value>-->
        </list>
    </property>
</bean>


<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="${jdbc.driverClassName}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>

<bean id="transactionManger" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>

<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="generateDdl" value="true" />-->
        </bean>
    </property>
    <property name="packagesToScan" value="com.bla.bla.model.domain"/>
    <property name="persistenceUnitName" value="default"/>
    <property name="jpaProperties">
        <props>
            <prop key="hibernate.dialect">${hibernate.dialect}</prop>
            <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
            <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
            <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
        </props>
    </property>
</bean>


<jpa:repositories base-package="com.bla.bla.model.dao"/>

persistence.xml(main/resources/META-INF 中 project-model-config.xml 的兄弟)也看起来像这样

<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
 <persistence-unit name="default" transaction-type="RESOURCE_LOCAL" />
</persistence>

属性 mysql.hibernate.properties/mysql.jdbc.properties

hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.show_sql=false
hibernate.format_sql=false
hibernate.hbm2ddl.auto=create

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.username=root
jdbc.password=mypass
jdbc.url=jdbc:mysql://localhost:3306/projectjava

com.bla.bla.model.domain 包包含一个实体帐户

   import java.io.Serializable;
   import java.util.Date;
   import javax.persistence.Basic;
   import javax.persistence.Column;
   import javax.persistence.Entity;
   import javax.persistence.Id;
   import javax.persistence.Table;


@Entity
@Table(name = "account")
public class Account implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @Basic(optional = false)
    @Column(name = "account_id")
    private Long ID;
    @Basic(optional = false)
    @Column(name = "name")
}

在成功构建(maven)之后,没有生成表。我什至使用简单的断言添加了一个测试。

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:META-INF/project-model-config.xml"})
public class AccountDAOTest {

 @Test
 public void testSetup(){
    Assert.assertTrue(true);
 }
}

所以我对如何生成实体有点困惑,我不明白为什么它不能。 任何人都可以看到这里的问题吗?

【问题讨论】:

  • 什么是 project-model-config.xml? 你得加载 applicationContext 对吧?
  • @ManuPK 很抱歉缺乏精确性。这与我在帖子第一部分显示的 applicationContext 相同。我对其进行了一些编辑以使其更清晰。
  • 您是否尝试过以下答案?我没有看到任何 cmets 或其他答案。如果有用,请点赞/接受答案。

标签: hibernate jakarta-ee entitymanager


【解决方案1】:

加载实体映射时,Hibernate 会生成表格。这意味着您的案例应该生成表格。

这看起来像是春季的问题,jpaVendorAdapter 在他们的JIRA 中告知。 还有一个SO问题here

现在,我不确定您是否需要在应用程序上下文中使用jpaVendorAdapter。我没有使用它,也没有在 Spring API docs 上找到它。不是强制的,让它初始化为默认的value

删除该映射并尝试执行代码。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-11-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-11-03
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多