使用Spring和Hibernate自动创建/更新表

时间:2015-09-27 21:29:01

标签: java spring hibernate spring-mvc autocreate

我有一个基于 Spring + Hibernate 的应用程序,其中大多数属性都是使用 注释 设置的。

我的 AppConfig类 如下所示:

//package declarations and imports 

@EnableWebMvc
@Configuration
@ComponentScan({ "com.package.subpackage.*" })
@Import({ SecurityConfig.class })
public class AppConfig {

    @Bean(name = "dataSource")
    public DriverManagerDataSource dataSource() {
        DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource();
        driverManagerDataSource.setDriverClassName("com.mysql.jdbc.Driver");
        driverManagerDataSource.setUrl("jdbc:mysql://localhost:3306/fur");
        Properties prop = new Properties();
        prop.setProperty("hibernate.hbm2ddl.auto", "create");
        driverManagerDataSource.setConnectionProperties(prop);
        driverManagerDataSource.setUsername("root");
        driverManagerDataSource.setPassword("");
        return driverManagerDataSource;
    }

    //other methods...

}

问题我的问题是与我的Java类关联的表格 不是在我的数据库中自动创建的

我不添加我班级的例子因为我认为它在配置问题上,但如果需要请告诉我。

1 个答案:

答案 0 :(得分:1)

您正在数据源上设置包含hibernate.hmb2ddl.auto的属性,该属性对ORM层(如Hibernate)一无所知。您应该将这些属性传递给LocalSessionFactoryBuilder bean等。

您可以使用类似的配置来设置具有所需属性的Hibernate:

@Configuration
public class DatabaseConfig {

    // Data source, transaction manager, ... bean definitions omitted

    @Bean
    public LocalSessionFactoryBuilder sessionFactoryBuilder() {
        LocalSessionFactoryBuilder sfb = new LocalSessionFactoryBuilder(dataSource());
        sfb.scanPackages("com.example.app.model");
        // Hibernate/JPA properties
        Properties properties = new Properties();
        properties.put("hibernate.dialect", "org.hibernate.dialect.MySQLDialect");
        properties.put("hibernate.hbm2ddl.auto", "create");
        sfb.addProperties(properties);
        return sfb;
    }

    @Bean
    public SessionFactory sessionFactory() {
        return sessionFactoryBuilder().buildSessionFactory();
    }

}