Создание DDL-скрипта при сборке MAVEN с помощью Hibernate4 / JPA 2.1
кажется hibernate3-maven-plugin
используется для создания сценариев DDL create / drop больше не совместим с Hibernate 4.3
и более новые версии (используя JPA 2.1
).
Я использую эту конфигурацию плагина :
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>hibernate3-maven-plugin</artifactId>
<version>3.0</version>
<executions>
<execution>
<id>generate-sql-schema</id>
<phase>process-sources</phase>
<goals>
<goal>hbm2ddl</goal>
</goals>
<configuration>
<hibernatetool>
<jpaconfiguration persistenceunit="${persistenceUnitName}" />
<hbm2ddl update="true" create="true" export="false"
outputfilename="src/main/sql/schema.sql" format="true"
console="true" />
</hibernatetool>
</configuration>
</execution>
</executions>
</plugin>
но я получаю следующую ошибку :
[ERROR] Failed to execute goal org.codehaus.mojo:hibernate3-maven-plugin:3.0:hbm2ddl (generate-sql-schema) on project my-project: There was an error creating the AntRun task.
An Ant BuildException has occured: java.lang.NoClassDefFoundError: org/hibernate/util/ReflectHelper: org.hibernate.util.ReflectHelper -> [Help 1]
этот класс как перенесенный в новый пакет:org.hibernate.internal.util.ReflectHelper
однако я не нашел четкого способа продолжать генерировать сценарии создания DDL в Maven build.
нет hibernate4-maven-plugin
, или любой другой официальный способ сделать это.
ну и что ? Разве это не основная функция, которая должна поддерживаться ? Как это сделать ?
2 ответов
As Hibernate 4.3+
теперь реализует JPA 2.1
соответствующий способ создания сценариев DDL-использовать следующий набор свойств JPA 2.1:
<property name="javax.persistence.schema-generation.scripts.action" value="create"/>
<property name="javax.persistence.schema-generation.create-source" value="metadata"/>
<property name="javax.persistence.schema-generation.scripts.create-target" value="target/jpa/sql/create-schema.sql"/>
хорошее резюме других свойств и контекста генерации схемы в JPA 2.1 можно найти здесь : https://blogs.oracle.com/arungupta/entry/jpa_2_1_schema_generation
и официальные спецификации JPA 2.1 здесь : https://jcp.org/aboutJava/communityprocess/final/jsr338/index.html
поскольку это будет создано во время выполнения, вы можете захотеть выполните это поколение DDL в build.
вот подход JPA 2.1 для создания этого сценария программно:
import java.io.IOException;
import java.util.Properties;
import javax.persistence.Persistence;
import org.hibernate.jpa.AvailableSettings;
public class JpaSchemaExport {
public static void main(String[] args) throws IOException {
execute(args[0], args[1]);
System.exit(0);
}
public static void execute(String persistenceUnitName, String destination) {
System.out.println("Generating DDL create script to : " + destination);
final Properties persistenceProperties = new Properties();
// XXX force persistence properties : remove database target
persistenceProperties.setProperty(org.hibernate.cfg.AvailableSettings.HBM2DDL_AUTO, "");
persistenceProperties.setProperty(AvailableSettings.SCHEMA_GEN_DATABASE_ACTION, "none");
// XXX force persistence properties : define create script target from metadata to destination
// persistenceProperties.setProperty(AvailableSettings.SCHEMA_GEN_CREATE_SCHEMAS, "true");
persistenceProperties.setProperty(AvailableSettings.SCHEMA_GEN_SCRIPTS_ACTION, "create");
persistenceProperties.setProperty(AvailableSettings.SCHEMA_GEN_CREATE_SOURCE, "metadata");
persistenceProperties.setProperty(AvailableSettings.SCHEMA_GEN_SCRIPTS_CREATE_TARGET, destination);
Persistence.generateSchema(persistenceUnitName, persistenceProperties);
}
}
как вы можете видеть, это очень просто !
теперь вы можете использовать это в AntTask или Maven build, как это (для MAVEN):
<plugin>
<artifactId>maven-antrun-plugin</artifactId>
<version>1.7</version>
<executions>
<execution>
<id>generate-ddl-create</id>
<phase>process-classes</phase>
<goals>
<goal>run</goal>
</goals>
<configuration>
<target>
<!-- ANT Task definition -->
<java classname="com.orange.tools.jpa.JpaSchemaExport"
fork="true" failonerror="true">
<arg value="${persistenceUnitName}" />
<arg value="target/jpa/sql/schema-create.sql" />
<!-- reference to the passed-in classpath reference -->
<classpath refid="maven.compile.classpath" />
</java>
</target>
</configuration>
</execution>
</executions>
</plugin>
отметим, что должностное лицо hibernate-maven-плагин также может, или не может, сделать трюк в некотором роде:
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-maven-plugin</artifactId>
<version>4.3.1.Final</version>
</dependency>
наслаждайтесь ! :)
Я могу немного опоздать, но у Эндрю Томпсона есть другое решение, которое не включает в себя настойчивость.xml или реальная база данных, хотя она специфична для спящего режима.
http://jandrewthompson.blogspot.com/2009/10/how-to-generate-ddl-scripts-from.html
к сожалению, это включает в себя немного код, но его очень гибким.