3

我有 Hibernate 工作,想尝试添加Envers 审计/修订功能,但似乎无法弄清楚需要什么。(我的示例编译并运行正常,我获得了常规的 Hibernate 功能,但我的数据库中没有出现审计表。)以前有人做过吗?它是否适用于使用 HSQLDB 方言的 H2 数据库?网上有没有简单完整的示例程序?

编辑:让我稍微改一下。最后,我希望我的构建过程创建一个 .jar 文件,我可以将其安装在另一台计算机上,并使用适当的 .properties 文件和 JDBC 驱动程序创建(或允许我创建)适当的数据库表(如果它们不存在)。我怎样才能做到这一点?

编辑:到目前为止,如果我想运行 Jamie B 建议的 ant 任务,我必须调整我的类路径,以便它找到隐藏在 Hibernate 工具 zip 中的 envers jar 文件和hibernate-tools jar 文件。而且我还没有让事情奏效。如果/当我这样做时,我想也许我可以创建一个 SQL 文件并将其作为资源放在我的最终 .jar 文件中,然后我可以在我的程序本身中使用它。(尽管考虑到安全问题,我的脑海中出现了一面红旗……嗯……)

4

3 回答 3

2

听起来您正在寻找以下休眠属性:

hibernate.hbm2ddl.auto

文档中:

创建 SessionFactory 时自动验证模式 DDL 或将其导出到数据库。

这会自动创建根据您设置的envers 属性命名的模式表。不需要额外的库或 ant 任务。

例如,我将它添加到hibernate.cfg.xmlupdate的开发数据库中。您还可以使用 Hibernate 的configuration对象以编程方式添加此属性。

于 2009-06-05T14:37:53.423 回答
1

您是否阅读了参考文档的第 6 章(www.jboss.org/file-access/default/members/envers/downloads/envers-1.2.0.ga-hibernate-3.3.pdf)?看起来 _AUD 表不是以标准 Hibernate 方式创建的;有一个 AntTask 可以增强它。

于 2009-05-22T20:27:00.270 回答
1

经过一些实验后,我用 envers 生成了工作表

我使用了这些参数 hibernate.hbm2ddl.auto=create-drop

出现错误是因为表存在,所以我认为,该参数 hibernate.hbm2ddl.auto=update 将解决它

日志:

    5755 [main] INFO org.hibernate.cfg.HbmBinder - Mapping class: myappcompany.base.Company_AUD -> company_AUD
5782 [main] INFO org.hibernate.cfg.HbmBinder - Mapping class: org.hibernate.envers.DefaultRevisionEntity -> REVINFO
5915 [main] INFO org.hibernate.impl.SessionFactoryImpl - building session factory
6746 [main] INFO org.hibernate.impl.SessionFactoryObjectFactory - Not binding factory to JNDI, no JNDI name configured
6784 [main] INFO org.hibernate.tool.hbm2ddl.SchemaExport - Running hbm2ddl schema export
6785 [main] INFO org.hibernate.tool.hbm2ddl.SchemaExport - exporting generated schema to database
9004 [main] ERROR org.hibernate.tool.hbm2ddl.SchemaExport - Unsuccessful: create table company (ID bigint not null auto_increment, CREATED datetime, CREATED_BY varchar(255), MODIFIED datetime, MODIFIED_BY varchar(255), NAME varchar(255) not null, primary key (ID))
9004 [main] ERROR org.hibernate.tool.hbm2ddl.SchemaExport - Table 'company' already exists
10227 [main] INFO org.hibernate.tool.hbm2ddl.SchemaExport - schema export complete

我的配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:p="http://www.springframework.org/schema/p" xmlns:util="http://www.springframework.org/schema/util"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.5.xsd">

    <!--
    Data Source config 
     -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close" p:driverClassName="${jdbc.driver}" p:url="${jdbc.url}"
        p:username="${jdbc.username}" p:password="${jdbc.password}" />

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"
        p:entity-manager-factory-ref="entityManagerFactory" />

    <!-- 
    JPA config   
    -->
    <tx:annotation-driven />

    <bean id="entityManagerFactory"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
        p:persistence-xml-location="${persistence.xml.location}"
        p:data-source-ref="dataSource">
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"
                p:showSql="true" p:generateDdl="true">
            </bean>
        </property>
        <property name="jpaProperties">
            <value>
                hibernate.ejb.naming_strategy=org.hibernate.cfg.DefaultNamingStrategy
                hibernate.dialect=${hibernate.dialect}
                hibernate.hbm2ddl.auto=${hibernate.hbm2ddl.auto}
            </value>
        </property>
    </bean>

    <bean
        class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" />
</beans>

过几天我会做一个完整的例子

于 2009-11-18T09:56:41.600 回答