Jak programově vygenerovat pomocí hbm2ddl DB schéma

publikováno: 11.5.2013

Pokud používáte Spring a Hibernate (pomocí JPA), pak můžete vygenerovat databázové schéma pomocí třídy SchemaExport následovně:

 

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:db-dev.xml")
public class SchemaExportTest {
@Autowired
private LocalContainerEntityManagerFactoryBean entityManagerFactory;
@SuppressWarnings("deprecation")
@Test
public void exportDatabaseSchema() {
PersistenceUnitInfo persistenceUnitInfo
= entityManagerFactory.getPersistenceUnitInfo();
Map<String, Object> jpaPropertyMap
= entityManagerFactory.getJpaPropertyMap(); Configuration configuration = new Ejb3Configuration()
.configure(persistenceUnitInfo, jpaPropertyMap)
.getHibernateConfiguration(); SchemaExport schema = new SchemaExport(configuration);
schema.setOutputFile("gen-schema.sql");
schema.create(false, false);
}
}

Poznámka 1: Konfigurace připojení do databáze je v souboru db-dev.xml, který je v classpath a používá se v něm třída LocalContainerEntityManagerFactoryBean.

Poznámka 2: Výsledný script se uloží do domovského adresáře projektu do souboru gen-schema.sql

Poznámka 3: Tento kód funguje pro Hibernate do verze 5 (která v době psaní tohoto článku doposud nevyšla. V této verzi Hibernate už nebude třída Ejb3Configuration, která se v tomto příkladě používá)

Reference

Splnilo to mé očekávání si zopakovat základy Spring framework. Je vidět že školení je dobře připravené, že tomu co školíte rozumíte, že vás to baví, vysvětlíte principy a je dobře

Petr

Díky za školenie. Rád som si to celé zopakoval a rozšíril povedomie o Stream API a možnostiach funkcionálneho programovania v Jave. Veľmi dobrý impulz začať prvky funkcionálneho programovania zavádzať

Anton

Nebyl problém, se kdykoliv na cokoliv zeptat, pokud nebylo něco jasné, nebo neco nefungovalo. Také upozornění na obvyklé chyby, které nejsou hned intuitivně jasné, jako "pořadí" zpracováni Streamu, jsem ocenil.

Marek


Novinky

22.3.2019: Termíny Java školení léto 2019
Nové termíny!!!

22.3.2019: Vyšla Java 12!
Java 12 je venku!!!

20.2.2019: JIB 1.0