gpt4 book ai didi

java - Spring JpaRepository 没有返回更新的数据

转载 作者:行者123 更新时间:2023-11-30 08:23:54 25 4
gpt4 key购买 nike

<分区>

我正在开发一个基于 Spring 的服务器。我有两个 Controllers 正在监听不同的 http 请求。它们都有一个引用相同 Repository 的变量,带有 @Autowired 注释。

@Controller
public class ClientController {
@Autowired
NodeRepository nodeRepository;
...
}

@Controller
public class NodeController {
@Autowired
NodeRepository nodeRepository;
...
}

所有的数据库操作都是通过NodeRepository完成的:

public interface NodeRepository extends JpaRepository<Node, Long>{
Node findByNodeId(long nodeId);
List<Node> findByStatusIn(Set<String> status);
List<Node> findByNodeIdIn(Set<Long> ids);
Node findByPhoneNumber(String phoneNumber);
Node findByCloudId(String cloudId);
Node findByDeviceDescription(String deviceDescription);
}

行为如下:

ClientController 收到一个新的请求时,它会被处理,Controller 会向外部设备发送一个请求并等待它的回答。
NodeController 收到此答复。因此,当应答到达时,收到的信息将保存在数据库中,并向 ClientController 发送信号以将其唤醒。

当这个 Controller 被唤醒并试图从数据库中检索更新的信息时,我的问题就来了。该信息不是刚刚存储的信息,而是之前存储的信息。

这是发生 block 和检索信息的 ClientController 的代码片段:

// Retrieves the list of nodes that are going to be requested
requestedNodes = (List<Node>) nodeRepository.findAll();

System.out.println("BEFORE");
for (Node node : nodes)
System.out.println(node.getNodeId() + ": " + node.getStatus());

// Sends a request to the nodes
// The Controller is blocked here until all answers have been received
fetchNodes(requestedNodes, DevicePing[0], null);

// Retrieves the list of nodes again
nodes = nodeRepository.findAll();

System.out.println("AFTER");
for (Node node : nodes)
System.out.println(node.getNodeId() + ": " + node.getStatus());

这是打印的数据:

BEFORE:
321: dead
1: dead
4: dead

AFTER:
321: dead
4: dead
1: dead

如您所见,状态是相同的,但第二次应该是“活着”。

我检查过数据是否正确存储,确实如此。在解锁 ClientController 之前,新数据在数据库中可用。

我还尝试使用 JDBC 检索新数据,而不是存储库。在这种情况下,新信息被正确检索。所以我认为它一定是与 Repository 相关的东西,但我找不到它是什么。可能存在一些缓存或刷新问题。我试图在保存新数据之后和检索数据之前立即执行 nodeRepository.flush(),但它不起作用。

我希望有人能帮助我。提前致谢

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