gpt4 book ai didi

java - 如何在 Lettuce Redis 客户端库中初始化 MapScanCursor?

转载 作者:可可西里 更新时间:2023-11-01 11:17:14 24 4
gpt4 key购买 nike

我正在尝试使用 Lettuce 的同步命令执行 HSCAN。问题是我想不出初始化 MapScanCursor 的正确方法。我在构造函数上没有成功,并且 MapScanCursor.INITIAL 给出类型 ScanCursor(也没有运气将其转换为 MapScanCursor)。

这是一个例子:

RedisClient redisClient = RedisClient.create("redis://" + url + ":" + port);
RedisHashCommands<String, String> redisCommands = redisClient.connect().sync();
List<String> fields = new LinkedList<>();

MapScanCursor<String, String> scanCursor = ?

do {
scanCursor = redisCommands.hscan(key, scanCursor);
fields.addAll(scanCursor.getMap().keySet());
} while (!scanCursor.isFinished());

我应该如何初始化“scanCursor”?

最佳答案

你有两个选择:

要回答您的问题,只需使用 hscan(key) 初始化 scanCursor

MapScanCursor<String, String> scanCursor = null;

do {
if (scanCursor == null) {
scanCursor = redisCommands.hscan(key);
} else {
scanCursor = redisCommands.hscan(key, scanCursor);
}
fields.addAll(scanCursor.getMap().keySet());
} while (!scanCursor.isFinished());

或者,您可以使用 ScanIterator(参见 Lettuce 4.4),它是一个Iterator,涵盖了 Redis SCAN 用法的复杂性:

ScanIterator<KeyValue<String, String>> iterator = ScanIterator.hscan(redisCommands, key);

while (iterator.hasNext()) {

KeyValue<String, String> next = iterator.next();
// …
}

更新

根据 tcfritchman 的评论更新了基于 do…while 的方法。

关于java - 如何在 Lettuce Redis 客户端库中初始化 MapScanCursor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44578055/

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