Краткий ответ: нет .
Если вы измените ваши bean-компоненты, вам придется вручную перенести существующую схему. Так что для миграции базы данных в стиле Rails вам придется искать в другом месте.
Однако вы можете легко сгенерировать начальные значения ddl из ваших компонентов Java. Пример ниже иллюстрирует создание схемы с EclipseLink версии 2.0:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="JPATestPU" transaction-type="RESOURCE_LOCAL">
<provider>
org.eclipse.persistence.jpa.PersistenceProvider
</provider>
<class>org.randompage.MyEntity</class>
<properties>
<property name="javax.persistence.jdbc.user" value="johndoe"/>
<property name="javax.persistence.jdbc.password" value="secret"/>
<property name="javax.persistence.jdbc.driver" value="org.h2.Driver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:h2:~/.h2/testdb;FILE_LOCK=NO"/>
<property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
<property name="eclipselink.logging.level" value="INFO"/>
</properties>
</persistence-unit>
</persistence>
Ключевой элемент здесь
<property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
Это говорит EclipseLink об удалении существующих таблиц и создании новых один раз из вашего сопоставления JPA. Эта процедура сильно зависит от поставщика, поэтому для других поставщиков JPA (Hibernate, OpenJPA ...) вам придется обратиться к их конкретной документации.