首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Redis数据检索

Redis数据检索
EN

Stack Overflow用户
提问于 2016-09-16 02:19:08
回答 2查看 1.2K关注 0票数 1

我在redis缓存中有一个如下结构的地图:

缓存条目:Map<String, Map<String, String>>

内部映射可以有多达25000个元素/存储桶。在redis中,有没有一种方法可以根据键( redis键、外部map的键和内部map的键)从内部映射中检索特定值,而不必在访问此redis缓存的Java方法中获取整个redis条目?

目前,如果我必须从内部映射中删除一个特定的键,可以通过以下方式完成:

代码语言:javascript
复制
Map<String, Map<String, String>> mapFromRedis = redis.get("myRediscacheKey");
Map<String, String> innerMap = new HashMap<>();
if (!mapFromRedis.isEmpty()) {
    innerMap = mapFromRedis.get("key");
}
if (innerMap.containsKey("keyToBeDeleted")) {
    innerMap.remove("keyToBeDeleted");
    mapFromRedis.put("key", innerMap);
}
redis.set("myRediscacheKey", mapFromRedis);
EN

回答 2

Stack Overflow用户

发布于 2016-09-16 10:18:27

您的数据结构有3级映射: Redis键、外部映射键和内部映射键。从您的示例中,我们可以获得以下映射:myRediscacheKey -> key -> keyToBeDeleted -> value

但Redis最多只能有两级映射,即HASH。为了实现您的目标,您必须将3级映射压缩为2级映射,甚至是1级映射。

压缩为2级映射

您可以将Redis key和您的外部map key组合为HASH的key,将内部map key作为HASH的字段。这样,我们就可以得到如下的2级映射:myRediscacheKey:key -> keyToBeDeleted -> value

代码语言:javascript
复制
// set inner map key
hset myRediscacheKey:key keyToBeDeleted value
// remove inner map key
hdel myRediscacheKey:key keyToBeDeleted

压缩为1级映射

您还可以将这3个键组合为一个键:myRediscacheKey:key:keyToBeDeleted -> value

代码语言:javascript
复制
// set inner map key
set myRediscacheKey:key:keyToBeDeleted value
// remove inner map key
del myRediscacheKey:key:keyToBeDeleted
票数 0
EN

Stack Overflow用户

发布于 2016-09-28 18:14:01

你可以用Redisson很容易的做到这一点。它允许通过Redisson处理的特殊引用对象将Redis对象引用到另一个Redis对象。以下是代码示例:

代码语言:javascript
复制
RMap<String, RMap<String, String>> mapFromRedis = redisson.getMap("myRediscacheKey");

// Redisson loads only small reference object 
// to another Redis map and NOT entire map
Map<String, String> innerMap = mapFromRedis.get("key");

if (innerMap.remove("keyToBeDeleted") != null) {
   // key has been deleted
}
// or with faster approach
if (innerMap.fastRemove("keyToBeDeleted") == 1) {
   // key has been deleted
}

就这样!您不需要在每个内部地图更改时执行大量更新。在幕后,它只使用Redis上的两个操作:gethdel

RMap扩展了标准的Java MapConcurrentMap接口。因此,您不需要处理键/连接/序列化。这都是Redisson做的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39517844

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档