如何使用纯java配置设置hbm2ddl.auto

如何使用纯java配置设置hbm2ddl.auto,java,hibernate,spring-mvc,Java,Hibernate,Spring Mvc,我很难找到解释和概述如何在Spring4中使用纯java配置设置hbm2ddl.auto的资料。 我不使用Spring Boot,因为我想更多地了解Spring的基本原理。当然,我希望避免应用程序中的所有XML文件 到目前为止,我能够配置和使用我的应用程序,但我必须手动创建表。我试图设置hbm2ddl.auto的尝试不会成功 这就是我所拥有的: @Configuration @启用事务管理 公共类数据源配置{ private static final String PROPERTY_NAME_

我很难找到解释和概述如何在Spring4中使用纯java配置设置hbm2ddl.auto的资料。 我不使用Spring Boot,因为我想更多地了解Spring的基本原理。当然,我希望避免应用程序中的所有XML文件

到目前为止,我能够配置和使用我的应用程序,但我必须手动创建表。我试图设置hbm2ddl.auto的尝试不会成功

这就是我所拥有的:

@Configuration
@启用事务管理 公共类数据源配置{

private static final String PROPERTY_NAME_DATABASE_DRIVER = "com.mysql.jdbc.Driver";
private static final String PROPERTY_NAME_DATABASE_PASSWORD = "db.password";
private static final String PROPERTY_NAME_DATABASE_URL = "db.url";
private static final String PROPERTY_NAME_DATABASE_USERNAME = "db.username";
private static final String PROPERTY_NAME_HIBERNATE_DIALECT = "hibernate.dialect";
private static final String PROPERTY_NAME_HIBERNATE_SHOW_SQL = "hibernate.show_sql";
private static final String PROPERTY_NAME_ENTITYMANAGER_PACKAGES_TO_SCAN = "entitymanager.packages.to.scan";

@Autowired
private Environment env;

@Bean
public DataSource dataSource() throws SQLException {
    System.out.println("--------------");
    System.out.println("Data Source Initialization");
    DriverManagerDataSource dataSource = new DriverManagerDataSource();
    dataSource.setDriverClassName("com.mysql.jdbc.Driver");
    dataSource.setUrl("jdbc:mysql://localhost:3306/myeventmanager");
    dataSource.setUsername("root");
    dataSource.setPassword("******");
    System.out.println("--------------");
    System.out.println("Initialized");
    System.out.println(dataSource.getConnection());
    return dataSource;
}

@Bean
public LocalSessionFactoryBean sessionFactory(DataSource dataSource) {
    LocalSessionFactoryBean sessionFactoryBean = new LocalSessionFactoryBean();
    sessionFactoryBean.setDataSource(dataSource);
    sessionFactoryBean.setPackagesToScan(new String[]{"com.ruruapps.domain"});
    Properties props = new Properties();
    props.setProperty("dialect", "org.hibernate.dialect.MySQLDialect");
    sessionFactoryBean.setHibernateProperties(props);
    return sessionFactoryBean;
}

@Bean
@Autowired
public HibernateTransactionManager transactionManager(SessionFactory sessionFactory) {
    HibernateTransactionManager transactionManager = new HibernateTransactionManager();
    transactionManager.setSessionFactory(sessionFactory);

    return transactionManager;
}

@Bean
public BeanPostProcessor persistenceTranslation() {
    return new PersistenceExceptionTranslationPostProcessor();
}

Properties hibernateProperties() {
    return new Properties() {
        {
            setProperty("hibernate.hbm2ddl.auto", env.getProperty("hibernate.hbm2ddl.auto"));
            setProperty("hibernate.dialect", env.getProperty("hibernate.dialect"));
            setProperty("hibernate.globally_quoted_identifiers", "true");
        }
    };
}
}


那么,正确的配置方法是什么呢?

您可以按如下方式实现

@Configuration
@EnableTransactionManagement
@ComponentScan({ "xxx.xxx.xxx" })
@PropertySource(value = { "classpath:application.properties" })
public class HibernateConfiguration {
@Autowired
private Environment environment;

@Bean
public LocalSessionFactoryBean sessionFactory() {
    LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
    sessionFactory.setDataSource(dataSource());
    sessionFactory.setPackagesToScan(new String[] { "com.ws.ppp.pojo" });
    sessionFactory.setHibernateProperties(hibernateProperties());
    return sessionFactory;
}

@Bean(name = "dataSource")
public DataSource dataSource() {
    DriverManagerDataSource dataSource = new DriverManagerDataSource();
    dataSource.setDriverClassName(environment.getRequiredProperty("jdbc.driverClassName"));
    dataSource.setUrl(environment.getRequiredProperty("jdbc.url"));
    dataSource.setUsername(environment.getRequiredProperty("jdbc.username"));
    dataSource.setPassword(environment.getRequiredProperty("jdbc.password"));
    return dataSource;
}

private Properties hibernateProperties() {
    Properties properties = new Properties();
    properties.put("hibernate.dialect", environment.getRequiredProperty("hibernate.dialect"));
    properties.put("hibernate.show_sql", environment.getRequiredProperty("hibernate.show_sql"));
    properties.put("hibernate.format_sql", environment.getRequiredProperty("hibernate.format_sql"));
    properties.put("hibernate.hbm2ddl.auto", environment.getRequiredProperty("hibernate.automaticschema"));
    properties.put("hibernate.search.default.directory_provider",
            environment.getRequiredProperty("hibernate.search.default.directory_provider"));
    properties.put("hibernate.search.default.indexBase",
            environment.getRequiredProperty("hibernate.search.default.indexBase"));

    return properties;
}

@Bean
@Autowired
public HibernateTransactionManager transactionManager(SessionFactory s) {
    HibernateTransactionManager txManager = new HibernateTransactionManager();
    txManager.setSessionFactory(s);
    return txManager;
}
}

这将是一个类似的过程

            private Properties hibernateProperties() {
                Properties properties = new Properties();
                properties.put("hibernate.dialect", environment.getRequiredProperty("hibernate.dialect"));
                properties.put("hibernate.show_sql", environment.getRequiredProperty("hibernate.show_sql"));
                properties.put("hibernate.format_sql", environment.getRequiredProperty("hibernate.format_sql"));
                properties.put("hibernate.hbm2ddl.auto", environment.getRequiredProperty("hibernate.automaticschema"));
                properties.put("hibernate.search.default.directory_provider",
                        environment.getRequiredProperty("hibernate.search.default.directory_provider"));
                properties.put("hibernate.search.default.indexBase",
                        environment.getRequiredProperty("hibernate.search.default.indexBase"));

                return properties;
            }

试试这个。

它是通过在服务器上运行应用程序来构建数据库,还是需要以其他方式执行它?到目前为止,它什么也没做。我通过运行应用程序来构建数据库。在创建sessionFactory时,它将在给定数据库上创建表。无论如何,您需要先创建数据库。这将仅创建表和关系。谢谢。我已经设置好了。我在.NET上使用了其他类似的工具。添加属性hibernateProperties和方法会使它工作吗,还是我也必须更改其他bean?我在SpringMVC项目中使用了这个。除此之外,我还有用于配置spring mvc的AppConfig类。@EnableWebMvc@Configuration@ComponentScanbasePackages=com.aaa.bbb公共类AppConfig扩展了WebMVCConfigureAdapter{除此之外,数据库属性如下jdbc.drivercassname=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost.. jdbc.username=root jdbc.password=hibernate.dialen=org.hibernate.dialen.mysqldialent hibernate.show\u sql=true hibernate.automaticschema=更新hibernate.automaticschema应创建的属性r更新