如何使用 org.hibernate.tool.EnversSchemaGenerator 生成 Envers 数据库模式?
-
10-12-2019 - |
题
我将 Hibernate 更新到 4.1.1.Final 版本。根据 文档 有两种方法可以生成数据库模式:
- 蚂蚁任务
org.hibernate.tool.ant.EnversHibernateToolTask
. - 跑步
org.hibernate.tool.EnversSchemaGenerator
来自爪哇。
Hibernate-tools 不适用于 Hibernate-4.1.1.Final。它有一个 阻塞错误.
我只找到了 发行说明 和一个 测试用例。那么我该如何使用 org.hibernate.tool.EnversSchemaGenerator
用我的 persistence.xml 和 Maven?
更新:
找到相关 Hibernate 论坛上的帖子. 。我的问题似乎还没有答案。
解决方案
聚普洛创建了 Hibernate 4 的 Maven 插件. 。该插件支持模式导出,包括 Envers。工作示例如下。查看 官方插件配置文档 获取所用选项的解释。
该插件生成 schema.sql
Maven 中的文件 /target
目录于 test
目标。或者您可以手动运行 hibernate4:export
目标是更新文件。
<project>
<build>
<plugins>
<plugin>
<groupId>de.juplo</groupId>
<artifactId>hibernate4-maven-plugin</artifactId>
<version>1.0.3</version>
<executions>
<execution>
<goals>
<goal>export</goal>
</goals>
</execution>
</executions>
<configuration>
<envers>true</envers>
<format>true</format>
<delimiter>;</delimiter>
<force>true</force>
<type>CREATE</type>
<target>SCRIPT</target>
<hibernateDialect>org.hibernate.dialect.PostgreSQL9Dialect</hibernateDialect>
</configuration>
</plugin>
</plugins>
</build>
</project>
其他提示
您不需要 Ant 或 Hibernate 工具。直接使用 EnversSchemaGenerator 非常简单,如下所示:
Configuration config = new Configuration();
//make sure you set the dialect correctly for your database (oracle for example below)
config.setProperty("hibernate.dialect","org.hibernate.dialect.Oracle10gDialect");
//add all of your entities
config.addAnnotatedClass(MyAnnotatedEntity.class);
SchemaExport export = new EnversSchemaGeneHator(config).export();
export.execute(true, false, false, false);
您还可以给它一个要写入的文件名,但上面的代码无论如何都会打印到系统日志中。
以下对我有用:
public static void main(String[] args) {
Ejb3Configuration jpaConfiguration = new Ejb3Configuration().configure("persistenceUnit", null);
jpaConfiguration.buildMappings();
Configuration hibernateConfiguration = jpaConfiguration.getHibernateConfiguration();
AuditConfiguration.getFor(hibernateConfiguration);
EnversSchemaGenerator esg = new EnversSchemaGenerator(hibernateConfiguration);
org.hibernate.tool.hbm2ddl.SchemaExport se = esg.export();
se.setOutputFile("sql/schema.sql");
se.setFormat(true);
se.setDelimiter(";");
se.drop(true, false);
se.create(true, false);
}
我也有同样的问题。现在有一个 Hibernate 4 Tools 版本:
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-tools</artifactId>
<version>4.0.0-CR1</version>
</dependency>
但是这个 Ant 片段不导出审计表,只导出“基本”表:
<target name="schema-export">
<taskdef name="hibernatetool" classname="org.hibernate.tool.ant.EnversHibernateToolTask" classpathref="classpath"/>
<hibernatetool destdir="sql">
<classpath refid="classpath"/>
<jpaconfiguration persistenceunit="persistenceUnit"/>
<hbm2ddl export="false" create="true" drop="true" format="true" outputfilename="schema.sql"/>
</hibernatetool>
</target>
与此代码相同:只有“基本”表,没有“_aud”表:
public static void main(String[] args) {
Ejb3Configuration jpaConfiguration = new Ejb3Configuration().configure("persistenceUnit", null);
Configuration hibernateConfiguration = jpaConfiguration.getHibernateConfiguration();
AuditConfiguration.getFor(hibernateConfiguration);
EnversSchemaGenerator esg = new EnversSchemaGenerator(hibernateConfiguration);
org.hibernate.tool.hbm2ddl.SchemaExport se = esg.export();
se.setOutputFile("sql/schema.sql");
se.setFormat(true);
se.setDelimiter(";");
se.drop(true, false);
se.create(true, false);
}
你还有兴趣吗?如果我找到解决问题的方法,我会通知您。也许其他人对我们有什么建议?
不隶属于 StackOverflow