Spring boot H2 создает схему базы данных из файла - PullRequest
0 голосов
/ 30 сентября 2018

У меня есть приложение, которое выполняет базу данных H2 в целях POC памяти, и мне нужно автоматически импортировать сценарии schema.sql и data.sql, которые находятся в моей папке src / main / resources.Из того, что я прочитал, размещение этих файлов в этой папке - это все, что требуется, и при запуске сервера я вижу, что они выполняются:

2018-09-30 14:01:45.644  INFO 9720 --- [           main] o.s.jdbc.datasource.init.ScriptUtils     : Executing SQL script from URL [file:/home/brandon/code/validus/music-web/target/classes/schema.sql]
2018-09-30 14:01:45.677  INFO 9720 --- [           main] o.s.jdbc.datasource.init.ScriptUtils     : Executed SQL script from URL [file:/home/brandon/code/validus/music-web/target/classes/schema.sql] in 33 ms.
2018-09-30 14:01:45.680  INFO 9720 --- [           main] o.s.jdbc.datasource.init.ScriptUtils     : Executing SQL script from URL [file:/home/brandon/code/validus/music-web/target/classes/data.sql]
2018-09-30 14:01:45.707  INFO 9720 --- [           main] o.s.jdbc.datasource.init.ScriptUtils     : Executed SQL script from URL [file:/home/brandon/code/validus/music-web/target/classes/data.sql] in 27 ms.

Проблема заключается в том, что при входе в системусхема пустаВот моя конфигурация JPA:

@Configuration
@EnableTransactionManagement
public class PersistenceJPAConfig {
    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean();
        em.setDataSource(dataSource());
        em.setPackagesToScan(new String[] { "com.validus" });

        JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
        em.setJpaVendorAdapter(vendorAdapter);
        em.setJpaProperties(additionalProperties());

        return em;
    }

    @Bean
    public DataSource dataSource() {
        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName("org.h2.Driver");
        dataSource.setUrl("jdbc:h2:mem:testdb");
        dataSource.setUsername("sa");
        dataSource.setPassword("");
        return dataSource;
    }

    @Bean
    public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
        JpaTransactionManager transactionManager = new JpaTransactionManager();
        transactionManager.setEntityManagerFactory(emf);

        return transactionManager;
    }

    @Bean
    public PersistenceExceptionTranslationPostProcessor exceptionTranslation() {
        return new PersistenceExceptionTranslationPostProcessor();
    }

    Properties additionalProperties() {
        Properties properties = new Properties();
//      properties.setProperty("hibernate.hbm2ddl.auto", "none");
        properties.setProperty("spring.jpa.generate-ddl", "false");
        properties.setProperty("spring.jpa.hibernate.ddl-auto", "create");
        properties.setProperty("hibernate.dialect", "org.hibernate.dialect.H2Dialect");
//      properties.setProperty("javax.persistence.schema-generation.database.action", "none");
//      properties.setProperty("javax.persistence.schema-generation.scripts.action", "none");
//      properties.setProperty("javax.persistence.schema-generation.create-source", "none");

        return properties;
    }
}

Мне удалось отключить генерацию на основе POJO, но я хочу, чтобы он автоматически импортировал schema.sql.Что мне здесь не хватает?

Спасибо

1 Ответ

0 голосов
/ 30 сентября 2018

создайте папку sql, чтобы вы могли поместить в нее свои сценарии sql и попробовать код в своем компоненте источника данных следующим образом:

 try {
            EmbeddedDatabaseBuilder dbBuilder = new EmbeddedDatabaseBuilder();
            return dbBuilder.setType(EmbeddedDatabaseType.H2)
                    .addScript("Classpath:sql/security.sql").build();
        }catch(Exception e) {
            logger.error("Embedded Datasource bean cannot be created !!", e);
            return null;
        }

надеюсь, это поможет

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...