[英]How to create Audit Log Trail in Hibernate?
以下是表结构:
id | createdby | createddate | tablename | columnname | primaryid | oldavalue | newvalue | remarks
我们得到定界文件,其中有一些值需要在4个表中更新。 四个表各有10列。 我们不知道要更新什么。 因此,我们只针对一个主要ID更新整行。
现在的挑战是:
如何在Hibernate中获取表名,列名?
如何获取旧价值; 在更新期间? 如何知道我们要更新的字段具有旧值,现在我们要插入新值? (我们尚未比较字段)
您可以实现Hibernate的EmptyInterceptor。 在EmptyInterceptor的方法中,您可以找到字段名称,先前值和当前值。
我最喜欢的工具是Hibernate Envers 。 您只需将实体注释为@Audited,然后envers会处理拦截器。
您还可以通过在执行操作之前和之后编写spring方面来使用Spring AOP,该方面将在审计表中插入数据
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.