当前位置: 首页 > 知识库问答 >
问题:

javax。坚持不懈当数据库中存在记录时,查询AuditEntity时EntityNotFoundException

施彬彬
2023-03-14

我目前正在使用Spring Boot 2.1.1。发布,Hibernate Envers 5.3.7。最终的

当我为我的用户类查询AuditEntity时,它会抛出javax。坚持不懈EntityNotFoundException表示我的用户记录不存在。然而,在数据库中它确实存在。有人知道为什么吗?

用户实体

@Entity
@EntityListeners(AuditingEntityListener.class)
@Audited
@Table(name = "[user]") 
@Getter
@Setter
@NoArgsConstructor
public class User implements Serializable {


    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @Column(nullable = false, unique = true)
    @Length(max = 20)
    @Unique
    private String username;

    @Column(nullable = false)
    private String password;

    @Column
    private String email;

    @Column(nullable = false)
    private String name;


    @Audited(targetAuditMode = NOT_AUDITED)
    @ManyToOne(fetch = FetchType.LAZY)
    @CreatedBy
    private User createByUser;

    @CreatedDate
    private LocalDateTime createDatetime;

    @Audited(targetAuditMode = NOT_AUDITED)
    @ManyToOne(fetch = FetchType.LAZY)
    @LastModifiedBy
    private User updateByUser;

    @LastModifiedDate
    private LocalDateTime updateDatetime;

    @Column
    private Boolean active = true;

    @Column
    private Boolean deleted = false;

}

在查询审核实体时,属性createByUser updateByUser抛出异常javax.persistence.EntityNotFound异常:无法找到ID为2的data.entity.用户。但是,在数据库中我有这个记录。

AuditReader auditReader = AuditReaderFactory.get(entityManager);
AuditQuery query = auditReader.createQuery().forRevisionsOfEntity(User.class, true, true);
query.add(AuditEntity.id().eq(id));

return query.getResultList();

编辑日期:2018-12-05

问题似乎是这个ID2记录的问题,我从后端插入这些记录,而不是通过前端,前端将在_aud表中生成一条记录。不确定这种审计逻辑是如何工作的。

共有1个答案

徐凌
2023-03-14

我算了一下,确实是因为_aud表的记录缺失。

我决定在Spring引导的Application类中创建一个例程,而不是直接将测试记录插入后端。

@SpringBootApplication(
        exclude = {DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class, DataSourceTransactionManagerAutoConfiguration.class})
@EntityScan(basePackageClasses = {WebApplication.class})
@EnableAsync
@EnableCaching
@EnableTransactionManagement
@EnableConfigurationProperties
public class WebApplication extends SpringBootServletInitializer {


    public static void main(String[] args) {
        SpringApplication.run(WebApplication.class, args);
    }

    @Bean
    public CommandLineRunner setUpInitialData(
            EntityRepository1 entityRepository1,
            EntityRepository2 entityRepository2) {

        return args -> {
        // do all data insertion here...
        };
    }
}

该表或_aud表必须还包含实体的相应条目。

 类似资料:
  • 我有一个Play框架应用程序,我使用的是Hibernate 4.2。5.最终版本(通过Maven依赖关系管理器检索)。我决定升级到Hibernate4.3。0.最后,成功重新编译我的应用程序并运行它。 我得到了下面的例外,并没有能够找出原因。我降级回到4.2.5,这个问题没有发生。然后,我尝试在4.2.5之后的每个最终版本中升级Hibernate。也就是说,我从4.2.5。最终到4.2.6。最后,

  • 创建在类路径资源[ApplicationContext.xml]中定义的名为“sessionFactory”的bean时出错:调用init方法失败;嵌套异常为java。lang.NoSuchMethodError:javax。坚持不懈唯一约束。name()Ljava/lang/String; 这有什么不对吗? 我用的是 有人告诉我这是“hibernate-jpa-2.0-api-1.0.0.jar

  • 我有一个问题,这似乎是非常类似于如何创建一个Jandex索引在Quarkus的类在一个外部模块,我仔细地按照所有建议的步骤(jandex maven插件,空beans.xml,索引其他依赖)。 与上述问题的一个明显区别是,quarkus在我的案例中没有找到第三方类,所以我尝试“索引其他依赖项”。然而,javax。坚持不懈AttributeConverter是maven模块javax的一部分。持久性

  • 我不明白为什么我的代码像窗帘一样,如果有人能解释一下,那就太棒了。我面临的问题。。。我有两张桌子。方法一开始,我就在“table1”中插入一些东西,插入之后,我开始事务。让我们假设代码流总是到达事务。回滚()。我希望第二个查询被回滚,但不是第一个查询。但在我看来,他们两个都是倒退的。 太长,读不下去了 预期结果: 第一个查询已提交 第二个查询已回滚 当前结果: 第一个查询被回滚 注:我不知道如何准

  • 我正在开发Spring Boot应用程序,在启动服务器时遇到了这个错误。我不确定是否错误地定义了任何注释或缺少任何依赖项。任何帮助都将不胜感激。 主要类: UserService类: UserDAO类: @repository公共类UserDAO实现IUserDAO{ Build.gradle: 错误消息: 我看到了所有相关的答案,并尝试实现这些建议,如添加依赖项、在主类中添加符号等。但它显示了相

  • 我在启动我的web应用程序时遇到了这个错误,我真的不知道问题出在哪里,全速: 组织。springframework。豆。工厂UnsatisfiedPendencyException:创建名为“usuarioController”的bean时出错,该名称在文件[C:\Users\Carlos\eclipsejee workspace.metadata.plugins\org.eclipse.wst.