Desde o 5.0 , agora você pode encontrar esses valores em um dedicado Enum: org.hibernate.boot.SchemaAutoTooling(aprimorado com o valor NONEdesde 5.2).
Ou melhor ainda, desde a versão 5.1 , você também pode usar a que combina ações JPA 2 e Hibernate DDL "herdadas".org.hibernate.tool.schema.Action Enum
Mas você ainda não pode configurar um DataSourceprogramaticamente com isso. Seria melhor usar isso combinado com, org.hibernate.cfg.AvailableSettings#HBM2DDL_AUTOmas o código atual espera um Stringvalor (trecho extraído de SessionFactoryBuilderImpl):
this.schemaAutoTooling = SchemaAutoTooling.interpret( (String) configurationSettings.get( AvailableSettings.HBM2DDL_AUTO ) );
… E enumvalores internos de ambos org.hibernate.boot.SchemaAutoToolinge org.hibernate.tool.schema.Actionnão são expostos publicamente.
A seguir, uma DataSourceconfiguração programática de exemplo (usada em um dos meus aplicativos Spring Boot) que usa uma aposta graças a, .name().toLowerCase()mas só funciona com valores sem traço (não create-droppor exemplo):
@Bean(name = ENTITY_MANAGER_NAME)
public LocalContainerEntityManagerFactoryBean internalEntityManagerFactory(
EntityManagerFactoryBuilder builder,
@Qualifier(DATA_SOURCE_NAME) DataSource internalDataSource) {
Map<String, Object> properties = new HashMap<>();
properties.put(AvailableSettings.HBM2DDL_AUTO, SchemaAutoTooling.CREATE.name().toLowerCase());
properties.put(AvailableSettings.DIALECT, H2Dialect.class.getName());
return builder
.dataSource(internalDataSource)
.packages(JpaModelsScanEntry.class, Jsr310JpaConverters.class)
.persistenceUnit(PERSISTENCE_UNIT_NAME)
.properties(properties)
.build();
}