gpt4 book ai didi

java - Javers Spring Boot 集成按实例 ID 查询生成器返回空结果

转载 作者:行者123 更新时间:2023-12-02 01:44:21 25 4
gpt4 key购买 nike

我正在使用此示例中的 springboot 集成:

https://github.com/l7777777b/organization-structure

这是我的 fork 示例:

https://github.com/javers/organization-structure

使用 mysql 和最新版本的 Javers 5.6.3、gradle 5.4.1 和 springboot 2.1.6.RELEASE。

首先,我不确定它是否是预期的行为,但是使用 QueryBuilder.byInstanceId 时,更改和快照返回空结果,但使用 QueryBuilder.byClass 时,它显示正确.

QueryBuilder.byInstanceId 可以显示新插入数据的结果,对于现有数据(服务启动之前数据库中已有的数据),它似乎无法获取。

重现它:

  1. 像往常一样运行服务./gradleworganization-struct-sql:bootRun
  2. 创建新人

     POST http://localhost:8080/view/person
    {
    "id": 1,
    "firstName": "Yang",
    "lastName": "Huajie",
    "sex": "MALE",
    "salary": 22,
    "position": "DEVELOPER"
    }
  3. 更新它,更改任何属性

  4. 使用此代码获取快照:

     QueryBuilder jqlQuery = QueryBuilder.byInstanceId("1", Person.class);
    List<CdoSnapshot> changes = javers.findSnapshots(jqlQuery.build());
    JsonConverter jsonConverter = javers.getJsonConverter();
    System.out.println(jsonConverter.toJson(changes));
  5. 它应该显示一些数据,然后重新启动服务。或者强行停止它并运行 1。
  6. 通过运行编号 4 再次获取相同的快照,它应该显示空结果。除非我插入新数据,否则将返回新插入的数据。

但是如果我将 QueryBuilder.byInstanceId(personId, Person.class); 更改为 QueryBuilder.byClass(Person.class); 我可以正确从数据库获取所有结果,但我只需要搜索特定的 id,这就是为什么我需要使用 byInstanceId

最佳答案

它看起来像 id 是 Integer 并且您正在将 String 值传递给 byInstanceId("1"),您可以尝试将其更改为 int 并检查 ex. byInstanceId(1)

关于java - Javers Spring Boot 集成按实例 ID 查询生成器返回空结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57471605/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com